成 | 語言 | 描述 |
結構 | HTML | 網頁元素和內容 |
表現 | CSS | 網頁元素頁面樣式 |
行為 | JavaScript | 網頁交互 |
HTML,超文本標記語言(Hyper Text Markup Language),是一門描述性語言。標記,標簽,元素,叫法不同,意思相同。HTML超文本標記語言主要通過標簽的方式,對網頁頁面的文本、圖片、音頻、視頻等內容進行描述。學習HTML,就是學習各種標簽,來搭建網頁的結構。
結構:!DOCTYPE
說明:作用是告訴瀏覽器用哪個文檔規范來解析文檔
標簽:html
說明:用于搭建HTML網頁文檔結構和網頁布局
?標簽:head
說明:用于定義HTML網頁文檔的頭部,它是所有頭部元素的容器?
?標簽:body
說明:用來定義HTML網頁文檔的主體區域?
?標簽:meta
說明:用來描述HTML網頁文檔的屬性?
?標簽:title
說明:用來放到HTML網頁文檔的頭部,是搜索引擎首要抓取的目標代碼?
標簽,也叫作標記,是由一對尖括號<>,里面包含單詞組成
<html></html>
<br>
嵌套關系
<html>
<head>
</head>
</html>
并列關系
<head>
</head>
<body>
</body>
注釋用來幫助程序員記錄程序設計方法,輔助程序閱讀
雙標簽,定義網頁的標題
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="utf-8">
<title>百度一下,你就知道了</title>
</head>
<body>
</body>
</html>
是單標簽,用來描述HTML網頁文檔的屬性
屬性值 | 說明 |
keywords | 網頁關鍵字,多個逗號隔開 |
description | 網頁描述 |
author | 作者 |
copyright | 版權信息 |
<!DOCTYPE html>
<html lang="en">
<head>
<!-- 網頁關鍵字 -->
<meta name="keywords" content="html,css,javascript">
<!-- 網頁描述 -->
<meta name="description" content="基礎前端知識">
<!-- 網頁作者 -->
<meta name="author" content="buddha">
<!-- 網頁版權信息 -->
<meta name="copyright" content="版權所有,翻版必究">
</head>
<body>
</body>
</html>
標簽屬性:
1、標簽的屬性寫在開始標簽內部
2、標簽名與屬性之間要有空格隔開
3、一個標簽可以同時存在多個屬性
4、屬性之間以空格隔開
5、屬性沒有先后順序之分
屬性值 | 說明 |
Content-Type | 定義網頁所使用編碼 |
refresh | 定義網頁自動刷新跳轉 |
<!DOCTYPE html>
<html lang="en">
<head>
<!-- 設置網頁編碼完整寫法 -->
<meta http-equiv="Content-Type" content="text/html;charset=utf-8">
<!-- 設置網頁編碼簡寫寫法 -->
<meta charset="UTF-8">
<!-- 網頁打開3秒后跳去百度 -->
<meta http-equiv="refresh" content="3;url=https://www.baidu.com">
</head>
<body>
</body>
</html>
是雙標簽,用來定義標簽的css樣式
<!DOCTYPE html>
<html lang="en">
<head>
<style type="text/css">
/* css內聯樣式寫這里 */
</style>
</head>
<body>
</body>
</html>
是單標簽,是用來引入外部css樣式文件
<link rel="stylesheet" href="css/index.css" type="text/css">
是雙標簽,是用來寫JavaScript代碼的地方
<!DOCTYPE html>
<html lang="en">
<head>
<script>
/* 這里寫JavaScript代碼 */
</script>
</head>
<body>
</body>
</html>
是單標簽,是用來設置整個網頁的基礎路徑。
<!DOCTYPE html>
<html lang="en">
<head>
<base href="https://pic.rmb.bdstatic.com">
</head>
<body>
<img src="bjh/news/e7fb4c2be6a2e439ff7e3197fa205d8f1336.gif">
</body>
</html>
開發中很少用到,有人使用知道就行
上面所述標簽是放在head標簽里的,接下來接觸的標簽都是放在body標簽內的
是雙標簽,h是header的縮寫
<h1>h1標簽:一級標題</h1>
<h2>h2標簽:二級標題</h2>
<h3>h3標簽:三級標題</h3>
<h4>h4標簽:四級標題</h4>
<h5>h5標簽:五級標題</h5>
<h6>h6標簽:六級標題</h6>
特點:
1、字體加粗
2、獨占一行
3、從h1到h6,字體逐漸減小
4、使用<h>標簽的主要意義是告訴搜索引擎這是一段文字的標題
5、<h1>在一個頁面最多只能有一個,不要用多個
是雙標簽,p是paragraph的縮寫
<p>這是一段文字</p>
<p>這是一段文字</p>
<p>這是一段文字</p>
特點:
1、獨占一行
2、段落與段落之間,存在間隙
是單標簽,br是break的縮寫
<p>這是一段<br>文字</p>
特點:
1、強制換行
2、單標簽
是單標簽,hr是horizon地平線的縮寫
<p>這是一段文字</p>
<hr>
<p>這是一段文字</p>
特點:
1、在頁面中顯示一條水平線
2、單標簽
標簽1 | 標簽2 | 說明 |
b | strong | 加粗 |
u | ins | 下劃線 |
i | em | 傾斜 |
s | del | 刪除線 |
<b>這是一段文字</b>
<strong>這是一段文字</strong>
<br>
<u>這是一段文字</u>
<ins>這是一段文字</ins>
<br>
<i>這是一段文字</i>
<em>這是一段文字</em>
<br>
<s>這是一段文字</s>
<del>這是一段文字</del>
特點:
1、不會獨占一行
2、推薦使用標簽2所在列標簽
sup是superscripted這個單詞的縮寫
<!DOCTYPE html>
<html lang="en">
<head>
</head>
<body>
a<sup>2</sup>
</body>
</html>
sub是subscripted這個單詞的縮寫
<!DOCTYPE html>
<html lang="en">
<head>
</head>
<body>
H<sub>2</sub>O
</body>
</html>
在網頁中展示特殊符號效果時,需要使用字符實體替代
顯示結果 | 描述 | 實體名稱 |
空格 |
| |
< | 小于號 | < |
> | 大于號 | > |
& | 與 | & |
" | 雙引號 | " |
x | 乘號 | × |
÷ | 除號 | ÷ |
- | 長破折號 | — |
| | 豎線 | | |
‘ | 左單引號 | ‘ |
‘ | 右單引號 | ’ |
? | 版權符 | © |
? | 注冊商標 | ® |
? | 商標 | ™ |
° | 度 | ° |
<img src="./001.jpg" alt="">
img標簽常見屬性:
屬性名 | 說明 |
src | 圖片路徑(絕對路徑、相對路徑) |
alt | 圖片加載失敗時,顯示的文字 |
title | 鼠標懸停時,顯示的文字 |
width | 圖片寬度 |
height | 圖片高度 |
只設置寬或高,會自動等比縮放,寬高只需要數字,不需要'px'
<img src="./001.jpg" alt="圖片加載失敗" title="這是程序兔" width="200" height="200">
絕對路徑:指目錄下的絕對位置,比如從根目錄開始的路徑,或完整的網絡地址
相對路徑:從當前文件開始出發找目標文件的過程
<audio src="music.mp3" controls autoplay loop></audio>
audio標簽常見屬性:
屬性名 | 說明 |
src | 音頻路徑 |
controls | 顯示播放控件 |
autoplay | 自動播放 |
loop | 循環播放 |
支持mp3、wav、ogg三種音頻格式
<video src="video.mp4" controls loop autoplay></video>
屬性名 | 說明 |
src | 視頻路徑 |
controls | 顯示播放控件 |
autoplay | 自動播放 |
loop | 循環播放 |
支持mp4、webm、ogg三種視頻格式
超鏈接,是雙標簽,實現各個獨立頁面之間進行跳轉,可以跳去站外也可以在站內之間跳轉
<a href="鏈接地址">文本或圖片</a>
站外跳轉,采用絕對路徑
<a href="http://www.baidu.com" target="_blank">百度</a>
站內跳轉,采用相對路徑
<!-- a頁面 -->
<a href="b.html">跳去b頁面</a>
<!-- b頁面 -->
<p>b頁面</p>
頁面內跳轉
<a href="#ms">美食</a>
<a href="#jd">景點</a>
<h3 id="ms">推薦美食</h3>
<!-- 省略n個br標簽 -->
<br>
<h3 id="jd">推薦景點</h3>
屬性名 | 說明 |
href | 跳轉鏈接 |
target | 鏈接打開方式 |
target屬性值
屬性值 | 說明 |
_self | 默認,原窗口打開鏈接 |
_blank | 在新窗口打開鏈接 |
_parent | 在父窗口打開鏈接 |
_top | 在頂層窗口打開超鏈接 |
target屬性值一般使用_self(默認)和_blank
<ul type="屬性值">
<li>列表項</li>
<li>列表項</li>
<li>列表項</li>
</ul>
解釋:
1、ul,unordered lists,無序列表,li,list item,列表項
2、ul標簽子標簽只允許是li標簽
3、li標簽可以包含任意內容
type屬性值
屬性值 | 說明 |
disc | 默認,實心圓 |
circle | 空心圓 |
square | 實心方型 |
<ul>
<li>你</li>
<li>我</li>
<li>他</li>
</ul>
<ol type="屬性值">
<li>列表項</li>
<li>列表項</li>
<li>列表項</li>
</ol>
解釋:
1、ol,ordered lists,有序列表,li,list item,列表項
2、ol標簽子標簽只允許是li標簽
3、li標簽可以包含任意內容
type屬性值
屬性值 | 說明 |
1 | 默認,阿拉伯數字,1,2,3...... |
a | 小寫英文字母,a,b,c...... |
A | 大寫英文字母,A,B,C...... |
i | 小寫羅馬數字,i,ii,iii...... |
I | 大寫羅馬數字,I,II,III...... |
<ol>
<li>你</li>
<li>我</li>
<li>他</li>
</ol>
<dl>
<dt>名詞</dt>
<dd>描述</dd>
……
</dl>
解釋:
1、dl,definition lists,自定義列表;dt,definition term,自定義列表組;dd,definition description,自定義列表描述
<dl>
<dt>稱呼</dt>
<dd>你</dd>
<dd>我</dd>
<dd>他</dd>
</dl>
<table>
<tr>
<td>單元格1</td>
<td>單元格2</td>
</tr>
<tr>
<td>單元格3</td>
<td>單元格4</td>
</tr>
</table>
解釋:
1、tr,table row,表格行;td,table data cell,表行單元格
<table>
<tr>
<td>1</td>
</tr>
</table>
屬性名 | 屬性值 | 描述 |
border | 數字 | 邊框寬度 |
width | 數字 | 表格寬度 |
height | 數字 | 表格高度 |
<table border="1" width="200" height="50">
<tr>
<td>1</td>
</tr>
</table>
<caption>標題內容</caption>,位于表格內第一行
<table border="1" width="200" height="50">
<caption>數字</caption>
<tr>
<td>1</td>
</tr>
</table>
<th></th>,th,table header cell,表頭單元格
<table border="1" width="200" height="50">
<caption>數字</caption>
<tr>
<th>序號</th>
</tr>
<tr>
<td>1</td>
</tr>
</table>
thead、tbody、tfoot
<table border="1" width="200" height="50">
<caption>數字</caption>
<thead>
<tr>
<th>序號</th>
</tr>
</thead>
<tbody>
<tr>
<td>1</td>
</tr>
</tbody>
<tfoot>
<tr>
<td>匯總</td>
</tr>
</tfoot>
</table>
屬性名 | 屬性值 | 說明 |
rowspan | 合并單元格個數 | 合并行,單元格垂直合并 |
colspan | 合并單元格個數 | 合并列,單元格水平合并 |
<td rowspan="跨越的行數"></td>
<td colspan="跨越的列數"></td>
<table border="1" width="200" height="50">
<caption>數字</caption>
<thead>
<tr>
<th>序號</th>
<th>金額</th>
<th>金額</th>
</tr>
</thead>
<tbody>
<tr>
<td>1</td>
<td rowspan="2">20</td>
<td rowspan="2">20</td>
</tr>
<tr>
<td>2</td>
</tr>
</tbody>
<tfoot>
<tr>
<td>匯總</td>
<td colspan="2">40</td>
</tr>
</tfoot>
</table>
雙標簽,包裹其它表單標簽
<form>
// 表單
</form>
form標簽的常用屬性
屬性 | 說明 |
name | 表單名稱 |
method | 提交方式 |
action | 提交地址 |
target | 打開方式 |
enctype | 編碼方式 |
name屬性
一個頁面中,表單可能不止一個。name屬性,用來區分不同的表單
<form name="myForm"></form>
method屬性
用來指定表單數據使用哪種提交方式給后端
屬性值 | 說明 |
get | get方式 |
post | post方式 |
<form method="get"></form>
action屬性
用來指定表單數據提交到哪個地址
<!-- 比如提交到index.php地址 -->
<form action="index.php"></form>
target屬性
該屬性跟a標簽的target屬性一樣,其屬性值也是四個,一般情況只用到_blank屬性值,默認也是這個值
<form target="_blank"></form>
enctype屬性
屬性值 | 說明 |
application/x-www-form-urlencoded | 在發送前編碼所有字符(默認) |
multipart/form-data | 不對字符編碼,在使用包含文件上傳控件的表單時,必須使用該值 |
text/plain | 空格轉換為 "+" 加號,但不對特殊字符編碼 |
<form enctype="multipart/form-data"></form>
input是單標簽
<input type="表單類型">
屬性值 | 說明 |
text | 單行文本框 |
password | 密碼文本框 |
radio | 單選框 |
checkbox | 多選框 |
button | 普通按鈕 |
submit | 提交按鈕 |
reset | 重置按鈕 |
file | 文件上傳 |
單行文本框常用屬性
屬性 | 說明 |
value | 設置文本框的默認值 |
size | 設置文本框的長度 |
maxlength | 設置最多可輸入字符 |
<form>
<input type="text" value="默認值" size="長度" maxlength="可輸入字符">
</form>
<form>
<label>姓名:<input type="text" value="曹操" size="20" maxlength="10"></label>
</form>
密碼文本框常用屬性
密碼文本框常用屬性和單行文本框常用屬性相同
<input type="password" value="默認值" size="長度" maxlength="可輸入字符">
<form>
<label>密碼:<input type="password" value="12345678" size="20" maxlength="10"></label>
</form>
單選框
屬性 | 說明 |
name | 組名,同組單選框,組名要相同,必要屬性 |
value | 單選框選項取值,必要屬性 |
checked | 默認選中項,同組單選框,可以有一個默認選中項 |
<input type="radio" name="組名" value="取值" checked="checked">
<form>
性別:
<input type="radio" name="sex" value="男" checked="checked">男
<input type="radio" name="sex" value="女">女
</form>
復選框
復選框和單選框的屬性都相同,區別復選框可以多選
<form>
愛好:
<input type="checkbox" name="hobby" value="籃球" checked>籃球
<input type="checkbox" name="hobby" value="足球" checked>足球
<input type="checkbox" name="hobby" value="臺球">臺球
</form>
普通按鈕
<input type="button" value="取值">
<form>
<input type="button" value="普通按鈕">
</form>
<button>普通按鈕</button>
區別:
1、input是單標簽,button是雙標簽
2、button標簽的信息除了文本,還可以是圖像、其它標簽等
3、button有type屬性,屬性值可以是button、submit、reset等
提交按鈕
<input type="submit" value="取值">
<form>
<input type="submit" value="提交">
</form>
把對應表單數據提交給后端服務器
重置按鈕
<input type="reset" value="取值">
<form>
<input type="reset" value="重置">
</form>
點擊重置后,所在form表單里所有內容被清空了
文件上傳
<input type="file">
<form>
<input type="file">
</form>
<textarea name="文本名稱" cols="列數" rows="行數"></textarea>
<form>
<textarea name="文本名稱" cols="1" rows="2"></textarea>
</form>
<select>
<option>選項內容</option>
<option>選項內容</option>
</select>
下拉列表標簽是為了節省頁面空間
select標簽屬性
屬性名 | 說明 |
name | 數據提交后端所需字段 |
size | 下拉選項顯示個數 |
multiple | 默認只允許選一個,選多個得加這個屬性 |
disabled | 所有下拉選項禁止選中 |
<form>
<select name="age" size="4" multiple="multiple" disabled="disabled">
<option>18歲以下</option>
<option>18-28歲</option>
<option>28-38歲</option>
<option>38歲以上</option>
</select>
</form>
option標簽屬性
屬性名 | 說明 |
selected | 默認選中 |
value | 被選中,數據提交后端的值 |
disabled | 該下拉選項禁止選中 |
<form>
<select name="age" size="5">
<option value="1">18歲以下</option>
<option value="2" disabled="disabled">18-28歲</option>
<option value="3" selected="selected">28-38歲</option>
<option value="4">38歲以上</option>
</select>
</form>
<iframe src="URL" width="數值" height="數值"></iframe>
框架標簽常用屬性
屬性名 | 說明 |
src | 嵌入的文檔地址 |
width | 標簽寬度 |
height | 標簽高度 |
<iframe src="https://www.bilibili.com" width="300" height="200"></iframe>
有些文檔禁止被嵌入
HTML標簽分為三種,行內標簽、塊級標簽和行內塊級標簽。
特點:
1、在頁面內只占據剛好能包裹自己內容的空間
2、沒有寬高,內容多大就多大,行內標簽不能嵌套塊級標簽(a標簽除外)
3、行內標簽設置寬高無效,可以對行高line-height進行設置
4、可以設置外邊距margin和內邊距padding,但只對左右邊距有效果,上下無效
5、常見行內標簽span、a、strong、ins、del、br等
span標簽
雙標簽,行內標簽,本身沒有固定樣式
<p>我是<span>中國人</span></p>
特點:
1、獨占一行
2、高度、寬度、外邊距、內邊距都可以設置生效
3、寬度默認是父級寬度的100%
4、是一個容器盒子,可以嵌套多層子級行內標簽、塊級標簽,文本類塊級標簽除外
5、常見塊級標簽div、p、h1~h6、ol、ul、li等
div標簽
雙標簽,塊級標簽,本身沒有固定樣式
<!-- 頭部區域 -->
<div></div>
<!-- 內容區域 -->
<div></div>
特點
1、在頁面內只占據剛好能包裹自己內容的空間
2、高度、寬度、外邊距、內邊距都可以設置生效
3、常見塊級標簽img、input、td
通過css樣式display屬性轉換,這是css的內容
著現代 Web 開發,我們要么使用 require 要么使用 import 引用 JavaScript 依賴項。有時,我們將兩者結合使用。
但是,你知道為什么這兩者都存在嗎? 使用一種或另一種時的最佳實踐是什么?
在本文中,我將討論使用 require 和 import 并回答其中一些常見問題。
在討論 require 和 import 之前,有必要對 JavaScript 模塊有一定的了解。 那么,讓我們看看有哪些不同類型的 JavaScript 模塊可用。
引入了 AMD 模塊以使模塊更加前端友好。 它們不需要任何打包器,并且所有依賴項都是動態解析的。
AMD使用 require 函數用于加載外部模塊,并且能夠充當 CommonJS 模塊的包裝器。
define("exampleModule", [], () => {
return {
print: () => console.log("Hello World!");
}
}
define("main", ["require", "exampleModule"], (require) => {
const exampleModule= require("exampleModule");
exampleModule.print();
});
但是,隨著 ES 模塊的引入,AMD 的使用量急劇減少。
CommonJS 是 NodeJS 用來在模塊中封裝 JavaScript 的標準。 module.exports用于導出 CommonJS 模塊,以及 import 函數用于將模塊包含到單獨的文件中。
盡管 CommonJS 模塊在 NodeJS 中被廣泛使用,但在前端開發中并沒有使用它們。 這背后的主要原因是require函數的同步行為。
但是,NodeJS 從 v13 開始才開始支持 ES 模塊。 在那之前,大多數 NodeJS 模塊,包括 NPM 庫,都是使用 CommonJS 模塊開發的。
因此,CommonJS 模塊仍然在開發人員中廣泛使用。
而且,CommonJS 模塊與 ES 模塊同樣重要,我將在本文接下來的部分中討論更多。
UMD 是 AMD 和 CommonJS 的組合。 它使用了 AMD 的 CommonJS 語法和異步加載技術,使其適用于服務器端和客戶端。
UMD 在 Webpack 等打包器中用作回退模塊,下面顯示了一個簡單的 UMD 模塊示例:
(function (root, factory) {
if (typeof define === "function" && define.amd) {
define(["jquery"], factory); // AMD } else if (typeof exports === "object" ) { module.exports = factory(require("jquery")); //CommonJS } else { root.returnExports = factory(root.jQuery); }
})(this, function ($) {
function exampleFunction() {}
return exampleFunction;
});
ES Modules (ECMAScript Modules) 是 JavaScript 中使用的官方標準。 ES 模塊使用 import和 export 處理模塊的語句。 它解決了 CommonJS 的最大限制之一,即同步加載。
在引入 ES Modules 之后,開發者之間有很多爭論,考慮到與 CommonJS 的兼容性。 但是,開發人員已經適應使用這兩種方法,我們將在接下來的部分中討論更多詳細信息。
已經了解了 JavaScript 模塊的背景,那么讓我們繼續討論 require 和 import.
require通常與 NodeJS 一起使用來讀取和執行 CommonJS 模塊。
這些模塊可以是內置模塊,如 http或自定義編寫的模塊。 使用 require,可以將它們包含在 JavaScript 文件中并使用它們的函數和變量。
// 內置模塊
const http= require('http');
// 本地模塊
const getBlogName = require('./blogDetails.js')
但是,如果要使用 require 要獲取本地模塊,首先需要使用 module.exports 導出它們.
例如,假設您有一個名為 blogDetails.js,并且您需要使用該文件中的函數 index.js文件。
// blogDetails.js
const getBlogTitle = (name, author) => {
return name + " by " + author;
}
modules.export = getBlogTitle;
// index.js
const getBlogTitle = require('./blogDetails.js');
var title = getBlogTitle ('Require vs Import in JavaScript', 'Chameera Dulanga');
還可以使用一次導出多個模塊 modules.export 如下:
const getBlogTitle = (name, author) => {
return name + " by " + author;
}
const getBlogContent = () => {
return content
}
modules.export = {
getBlogTitle,
getBlogContent,
};
注意: 如果最后不是使用 modules.export,可以附加 exports 。 例如: exports.getBlogContent = () => {};
我想現在你明白什么時候應該使用 require以及它是如何工作的。 接下來讓我們看看如何 import 。 然后我們將能夠以更深層次的理解來比較和對比它們。
import 是一個 ES 模塊,并帶有 export,它們被稱為 ES6 import 和 export.
我們不能用 import 或導出到 ES 模塊之外。
試圖 import ES 模塊之外是一個常見的開發人員錯誤。
如果我舉同樣的例子,我需要做的唯一改變就是修改 modules.export到 export default.
const getBlogTitle = (name, author) => {
return name + " by " + author;
}
export default getBlogTitle;
然后我們可以使用 import 將此文件包含在我們的 index.js文件。
import getBlogTitle from "./blogDetails.js";
var title = getBlogTitle ('Require vs Import in JavaScript', 'Chameera Dulanga');
注意: 類似于 require,還可以通過將導出附加到每個函數定義來單獨導出每個函數。
例如: export const = getBlogContent = () => {};
所以,我想你現在明白應該如何以及何時使用 require和 import。但是,這還不是全部; 它們的功能和用法存在一些顯著差異。 是時候進行比較了。
require 和 import 都用于包含模塊。 但是它們有幾個應該注意的重要功能。
import 語句只能在文件的開頭定義。 定義一個 import 其他地方的語句會給你一個錯誤或自動轉移到文件的開頭。
聲明 require 時,當加載的模塊名稱未預定義時,允許有條件地或動態地加載模塊。
例如,你可以調用 require 在函數或 if 條件中,如下所示:
if(articleCount>0){
const getBlogTitle = require(‘./blogDetails.js’);
}
require語句具有這種靈活性,因為它們被視為函數。 它們在運行時被調用,在此之前沒有辦法知道任何事情。 但, import 語句是靜態的,我們不能有條件地或動態地使用它們。
注意: 由于 import 語句是靜態的,所以可以在運行應用程序之前檢測到任何錯誤
在小型應用程序中,同步或異步可能不會發揮主要作用。 但是,如果我們考慮大型應用程序,則會使用數百個模塊。 所以,如果你使用 require, 模塊將被一 一加載和處理。
而 import 語句通過異步工作解決了這個問題,這比 require 在大規模應用中更能發揮作用。
正如我們所討論的,ES 模塊系統是作為維護客戶端 JavaScript 模塊的標準引入的。 TypeScript 也采用了它,并添加了用于定義 Type 的內容。 因此,我不認為 require可以再次取代 ES,因為它已成為開發人員中廣泛使用的標準。
但是由于有大量的 NodeJS 模塊和庫是用 CommonJS 編寫的,我們不能保留 require完全放在一邊。 所以我們必須相應地使用它們。
如果你使用的是 TypeScript,則可以通過配置 tsconfig.json文件。 例如,假設我們需要輸出一個使用 CommonJS 的代碼版本。
需要做的就是創建一個新的 tsconfig 通過擴展原始文件用于 CommonJS 輸出 tsconfig文件并修改 module下參數 CompilerOptions.
{
"extends": "./tsconfig.json",
"compilerOptions": {
"module": "CommonJS",
"outDir": "./lib/cjs"
},
}
注意: 還可以使用 Webpack 等構建工具將 ES 模塊轉換為 CommonJS 模塊。
以下表格為比較兩者
特征 | require | import |
語法 | const x=require() | import x from './' |
模塊 | CommonJS | ES |
異步 | 不支持 | 支持 |
HTML文檔中的任何地方可包括JavaScript代碼。但也有以下的最佳方法來包含JavaScript在HTML文件。
在 <head>...</head> 部分。
在 <body>...</body> 部分。
在<body>...</body> 和<head>...</head> 部分。
腳本和外部文件,然后包括在<head>... </ head>部分。
在下面的章節中,我們將看到如何可以包含JavaScript方式的不同:
如果你想在一些事件上運行一個腳本,當用戶點擊某個地方,如,那么應該腳本的頭部,如下所示:
<html>
<head>
<script type="text/javascript">
<!--
function sayHello() {
alert("Hello World")
}
//-->
</script>
</head>
<body>
<input type="button" onclick="sayHello()" value="Say Hello" />
</body>
</html>
123456789101112131415復制代碼類型:[javascript]
這將產生以下結果:
如果需要一個腳本的頁面加載,以便腳本生成頁面內容來運行,該腳本在文檔的<body>部分。在這種情況下,就不必使用JavaScript定義的所有功能:
<html>
<head>
</head>
<body>
<script type="text/javascript">
<!--
document.write("Hello World")
//-->
</script>
<p>This is web page body </p>
</body>
</html>
12345678910111213復制代碼類型:[javascript]
你可以把JavaScript代碼在<head>和<body>部分完全如下:
<html>
<head>
<script type="text/javascript">
<!--
function sayHello() {
alert("Hello World")
}
//-->
</script>
</head>
<body>
<script type="text/javascript">
<!--
document.write("Hello World")
//-->
</script>
<input type="button" onclick="sayHello()" value="Say Hello" />
</body>
</html>12345678910111213141516171819復制代碼類型:[javascript]
當開始工作,更廣泛地使用JavaScript,可能會發現有情況下,在站點的多個頁面重用相同的JavaScript代碼。
你并不局限于將保持在多個HTML文件相同的代碼。 script標簽提供了一種機制,允許存儲JavaScript在外部文件中,然后將其包含到HTML文件。
下面是一個例子來說明如何使用腳本標記和src屬性包含在HTML代碼的外部JavaScript文件:
<html>
<head>
<script type="text/javascript" src="filename.js" ></script>
</head>
<body>
.......
</body>
</html>
12345678910復制代碼類型:[javascript]
使用JavaScript從外部文件源,則需要使用擴展寫下所有的JavaScript代碼在一個簡單的文本文件“.js”,然后包括文件,如上圖所示。
例如,你可以保持在以下文件filename.js的內容,然后包括filename.js文件后,在HTML文件中使用sayHellofunction:
function sayHello() {
alert("Hello World")
}
開課吧廣場-人才學習交流平臺
*請認真填寫需求信息,我們會在24小時內與您取得聯系。