成 | 語言 | 描述 |
結(jié)構(gòu) | HTML | 網(wǎng)頁元素和內(nèi)容 |
表現(xiàn) | CSS | 網(wǎng)頁元素頁面樣式 |
行為 | JavaScript | 網(wǎng)頁交互 |
HTML,超文本標(biāo)記語言(Hyper Text Markup Language),是一門描述性語言。標(biāo)記,標(biāo)簽,元素,叫法不同,意思相同。HTML超文本標(biāo)記語言主要通過標(biāo)簽的方式,對網(wǎng)頁頁面的文本、圖片、音頻、視頻等內(nèi)容進行描述。學(xué)習(xí)HTML,就是學(xué)習(xí)各種標(biāo)簽,來搭建網(wǎng)頁的結(jié)構(gòu)。
結(jié)構(gòu):!DOCTYPE
說明:作用是告訴瀏覽器用哪個文檔規(guī)范來解析文檔
標(biāo)簽:html
說明:用于搭建HTML網(wǎng)頁文檔結(jié)構(gòu)和網(wǎng)頁布局
?標(biāo)簽:head
說明:用于定義HTML網(wǎng)頁文檔的頭部,它是所有頭部元素的容器?
?標(biāo)簽:body
說明:用來定義HTML網(wǎng)頁文檔的主體區(qū)域?
?標(biāo)簽:meta
說明:用來描述HTML網(wǎng)頁文檔的屬性?
?標(biāo)簽:title
說明:用來放到HTML網(wǎng)頁文檔的頭部,是搜索引擎首要抓取的目標(biāo)代碼?
標(biāo)簽,也叫作標(biāo)記,是由一對尖括號<>,里面包含單詞組成
<html></html>
<br>
嵌套關(guān)系
<html>
<head>
</head>
</html>
并列關(guān)系
<head>
</head>
<body>
</body>
注釋用來幫助程序員記錄程序設(shè)計方法,輔助程序閱讀
雙標(biāo)簽,定義網(wǎng)頁的標(biāo)題
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="utf-8">
<title>百度一下,你就知道了</title>
</head>
<body>
</body>
</html>
是單標(biāo)簽,用來描述HTML網(wǎng)頁文檔的屬性
屬性值 | 說明 |
keywords | 網(wǎng)頁關(guān)鍵字,多個逗號隔開 |
description | 網(wǎng)頁描述 |
author | 作者 |
copyright | 版權(quán)信息 |
<!DOCTYPE html>
<html lang="en">
<head>
<!-- 網(wǎng)頁關(guān)鍵字 -->
<meta name="keywords" content="html,css,javascript">
<!-- 網(wǎng)頁描述 -->
<meta name="description" content="基礎(chǔ)前端知識">
<!-- 網(wǎng)頁作者 -->
<meta name="author" content="buddha">
<!-- 網(wǎng)頁版權(quán)信息 -->
<meta name="copyright" content="版權(quán)所有,翻版必究">
</head>
<body>
</body>
</html>
標(biāo)簽屬性:
1、標(biāo)簽的屬性寫在開始標(biāo)簽內(nèi)部
2、標(biāo)簽名與屬性之間要有空格隔開
3、一個標(biāo)簽可以同時存在多個屬性
4、屬性之間以空格隔開
5、屬性沒有先后順序之分
屬性值 | 說明 |
Content-Type | 定義網(wǎng)頁所使用編碼 |
refresh | 定義網(wǎng)頁自動刷新跳轉(zhuǎn) |
<!DOCTYPE html>
<html lang="en">
<head>
<!-- 設(shè)置網(wǎng)頁編碼完整寫法 -->
<meta http-equiv="Content-Type" content="text/html;charset=utf-8">
<!-- 設(shè)置網(wǎng)頁編碼簡寫寫法 -->
<meta charset="UTF-8">
<!-- 網(wǎng)頁打開3秒后跳去百度 -->
<meta http-equiv="refresh" content="3;url=https://www.baidu.com">
</head>
<body>
</body>
</html>
是雙標(biāo)簽,用來定義標(biāo)簽的css樣式
<!DOCTYPE html>
<html lang="en">
<head>
<style type="text/css">
/* css內(nèi)聯(lián)樣式寫這里 */
</style>
</head>
<body>
</body>
</html>
是單標(biāo)簽,是用來引入外部css樣式文件
<link rel="stylesheet" href="css/index.css" type="text/css">
是雙標(biāo)簽,是用來寫JavaScript代碼的地方
<!DOCTYPE html>
<html lang="en">
<head>
<script>
/* 這里寫JavaScript代碼 */
</script>
</head>
<body>
</body>
</html>
是單標(biāo)簽,是用來設(shè)置整個網(wǎng)頁的基礎(chǔ)路徑。
<!DOCTYPE html>
<html lang="en">
<head>
<base href="https://pic.rmb.bdstatic.com">
</head>
<body>
<img src="bjh/news/e7fb4c2be6a2e439ff7e3197fa205d8f1336.gif">
</body>
</html>
開發(fā)中很少用到,有人使用知道就行
上面所述標(biāo)簽是放在head標(biāo)簽里的,接下來接觸的標(biāo)簽都是放在body標(biāo)簽內(nèi)的
是雙標(biāo)簽,h是header的縮寫
<h1>h1標(biāo)簽:一級標(biāo)題</h1>
<h2>h2標(biāo)簽:二級標(biāo)題</h2>
<h3>h3標(biāo)簽:三級標(biāo)題</h3>
<h4>h4標(biāo)簽:四級標(biāo)題</h4>
<h5>h5標(biāo)簽:五級標(biāo)題</h5>
<h6>h6標(biāo)簽:六級標(biāo)題</h6>
特點:
1、字體加粗
2、獨占一行
3、從h1到h6,字體逐漸減小
4、使用<h>標(biāo)簽的主要意義是告訴搜索引擎這是一段文字的標(biāo)題
5、<h1>在一個頁面最多只能有一個,不要用多個
是雙標(biāo)簽,p是paragraph的縮寫
<p>這是一段文字</p>
<p>這是一段文字</p>
<p>這是一段文字</p>
特點:
1、獨占一行
2、段落與段落之間,存在間隙
是單標(biāo)簽,br是break的縮寫
<p>這是一段<br>文字</p>
特點:
1、強制換行
2、單標(biāo)簽
是單標(biāo)簽,hr是horizon地平線的縮寫
<p>這是一段文字</p>
<hr>
<p>這是一段文字</p>
特點:
1、在頁面中顯示一條水平線
2、單標(biāo)簽
標(biāo)簽1 | 標(biāo)簽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、推薦使用標(biāo)簽2所在列標(biāo)簽
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>
在網(wǎng)頁中展示特殊符號效果時,需要使用字符實體替代
顯示結(jié)果 | 描述 | 實體名稱 |
空格 |
| |
< | 小于號 | < |
> | 大于號 | > |
& | 與 | & |
" | 雙引號 | " |
x | 乘號 | × |
÷ | 除號 | ÷ |
- | 長破折號 | — |
| | 豎線 | | |
‘ | 左單引號 | ‘ |
‘ | 右單引號 | ’ |
? | 版權(quán)符 | © |
? | 注冊商標(biāo) | ® |
? | 商標(biāo) | ™ |
° | 度 | ° |
<img src="./001.jpg" alt="">
img標(biāo)簽常見屬性:
屬性名 | 說明 |
src | 圖片路徑(絕對路徑、相對路徑) |
alt | 圖片加載失敗時,顯示的文字 |
title | 鼠標(biāo)懸停時,顯示的文字 |
width | 圖片寬度 |
height | 圖片高度 |
只設(shè)置寬或高,會自動等比縮放,寬高只需要數(shù)字,不需要'px'
<img src="./001.jpg" alt="圖片加載失敗" title="這是程序兔" width="200" height="200">
絕對路徑:指目錄下的絕對位置,比如從根目錄開始的路徑,或完整的網(wǎng)絡(luò)地址
相對路徑:從當(dāng)前文件開始出發(fā)找目標(biāo)文件的過程
<audio src="music.mp3" controls autoplay loop></audio>
audio標(biāo)簽常見屬性:
屬性名 | 說明 |
src | 音頻路徑 |
controls | 顯示播放控件 |
autoplay | 自動播放 |
loop | 循環(huán)播放 |
支持mp3、wav、ogg三種音頻格式
<video src="video.mp4" controls loop autoplay></video>
屬性名 | 說明 |
src | 視頻路徑 |
controls | 顯示播放控件 |
autoplay | 自動播放 |
loop | 循環(huán)播放 |
支持mp4、webm、ogg三種視頻格式
超鏈接,是雙標(biāo)簽,實現(xiàn)各個獨立頁面之間進行跳轉(zhuǎn),可以跳去站外也可以在站內(nèi)之間跳轉(zhuǎn)
<a href="鏈接地址">文本或圖片</a>
站外跳轉(zhuǎn),采用絕對路徑
<a href="http://www.baidu.com" target="_blank">百度</a>
站內(nèi)跳轉(zhuǎn),采用相對路徑
<!-- a頁面 -->
<a href="b.html">跳去b頁面</a>
<!-- b頁面 -->
<p>b頁面</p>
頁面內(nèi)跳轉(zhuǎn)
<a href="#ms">美食</a>
<a href="#jd">景點</a>
<h3 id="ms">推薦美食</h3>
<!-- 省略n個br標(biāo)簽 -->
<br>
<h3 id="jd">推薦景點</h3>
屬性名 | 說明 |
href | 跳轉(zhuǎn)鏈接 |
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標(biāo)簽子標(biāo)簽只允許是li標(biāo)簽
3、li標(biāo)簽可以包含任意內(nèi)容
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標(biāo)簽子標(biāo)簽只允許是li標(biāo)簽
3、li標(biāo)簽可以包含任意內(nèi)容
type屬性值
屬性值 | 說明 |
1 | 默認,阿拉伯?dāng)?shù)字,1,2,3...... |
a | 小寫英文字母,a,b,c...... |
A | 大寫英文字母,A,B,C...... |
i | 小寫羅馬數(shù)字,i,ii,iii...... |
I | 大寫羅馬數(shù)字,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 | 數(shù)字 | 邊框?qū)挾?/span> |
width | 數(shù)字 | 表格寬度 |
height | 數(shù)字 | 表格高度 |
<table border="1" width="200" height="50">
<tr>
<td>1</td>
</tr>
</table>
<caption>標(biāo)題內(nèi)容</caption>,位于表格內(nèi)第一行
<table border="1" width="200" height="50">
<caption>數(shù)字</caption>
<tr>
<td>1</td>
</tr>
</table>
<th></th>,th,table header cell,表頭單元格
<table border="1" width="200" height="50">
<caption>數(shù)字</caption>
<tr>
<th>序號</th>
</tr>
<tr>
<td>1</td>
</tr>
</table>
thead、tbody、tfoot
<table border="1" width="200" height="50">
<caption>數(shù)字</caption>
<thead>
<tr>
<th>序號</th>
</tr>
</thead>
<tbody>
<tr>
<td>1</td>
</tr>
</tbody>
<tfoot>
<tr>
<td>匯總</td>
</tr>
</tfoot>
</table>
屬性名 | 屬性值 | 說明 |
rowspan | 合并單元格個數(shù) | 合并行,單元格垂直合并 |
colspan | 合并單元格個數(shù) | 合并列,單元格水平合并 |
<td rowspan="跨越的行數(shù)"></td>
<td colspan="跨越的列數(shù)"></td>
<table border="1" width="200" height="50">
<caption>數(shù)字</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>
雙標(biāo)簽,包裹其它表單標(biāo)簽
<form>
// 表單
</form>
form標(biāo)簽的常用屬性
屬性 | 說明 |
name | 表單名稱 |
method | 提交方式 |
action | 提交地址 |
target | 打開方式 |
enctype | 編碼方式 |
name屬性
一個頁面中,表單可能不止一個。name屬性,用來區(qū)分不同的表單
<form name="myForm"></form>
method屬性
用來指定表單數(shù)據(jù)使用哪種提交方式給后端
屬性值 | 說明 |
get | get方式 |
post | post方式 |
<form method="get"></form>
action屬性
用來指定表單數(shù)據(jù)提交到哪個地址
<!-- 比如提交到index.php地址 -->
<form action="index.php"></form>
target屬性
該屬性跟a標(biāo)簽的target屬性一樣,其屬性值也是四個,一般情況只用到_blank屬性值,默認也是這個值
<form target="_blank"></form>
enctype屬性
屬性值 | 說明 |
application/x-www-form-urlencoded | 在發(fā)送前編碼所有字符(默認) |
multipart/form-data | 不對字符編碼,在使用包含文件上傳控件的表單時,必須使用該值 |
text/plain | 空格轉(zhuǎn)換為 "+" 加號,但不對特殊字符編碼 |
<form enctype="multipart/form-data"></form>
input是單標(biāo)簽
<input type="表單類型">
屬性值 | 說明 |
text | 單行文本框 |
password | 密碼文本框 |
radio | 單選框 |
checkbox | 多選框 |
button | 普通按鈕 |
submit | 提交按鈕 |
reset | 重置按鈕 |
file | 文件上傳 |
單行文本框常用屬性
屬性 | 說明 |
value | 設(shè)置文本框的默認值 |
size | 設(shè)置文本框的長度 |
maxlength | 設(shè)置最多可輸入字符 |
<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>
復(fù)選框
復(fù)選框和單選框的屬性都相同,區(qū)別復(fù)選框可以多選
<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>
區(qū)別:
1、input是單標(biāo)簽,button是雙標(biāo)簽
2、button標(biāo)簽的信息除了文本,還可以是圖像、其它標(biāo)簽等
3、button有type屬性,屬性值可以是button、submit、reset等
提交按鈕
<input type="submit" value="取值">
<form>
<input type="submit" value="提交">
</form>
把對應(yīng)表單數(shù)據(jù)提交給后端服務(wù)器
重置按鈕
<input type="reset" value="取值">
<form>
<input type="reset" value="重置">
</form>
點擊重置后,所在form表單里所有內(nèi)容被清空了
文件上傳
<input type="file">
<form>
<input type="file">
</form>
<textarea name="文本名稱" cols="列數(shù)" rows="行數(shù)"></textarea>
<form>
<textarea name="文本名稱" cols="1" rows="2"></textarea>
</form>
<select>
<option>選項內(nèi)容</option>
<option>選項內(nèi)容</option>
</select>
下拉列表標(biāo)簽是為了節(jié)省頁面空間
select標(biāo)簽屬性
屬性名 | 說明 |
name | 數(shù)據(jù)提交后端所需字段 |
size | 下拉選項顯示個數(shù) |
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標(biāo)簽屬性
屬性名 | 說明 |
selected | 默認選中 |
value | 被選中,數(shù)據(jù)提交后端的值 |
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="數(shù)值" height="數(shù)值"></iframe>
框架標(biāo)簽常用屬性
屬性名 | 說明 |
src | 嵌入的文檔地址 |
width | 標(biāo)簽寬度 |
height | 標(biāo)簽高度 |
<iframe src="https://www.bilibili.com" width="300" height="200"></iframe>
有些文檔禁止被嵌入
HTML標(biāo)簽分為三種,行內(nèi)標(biāo)簽、塊級標(biāo)簽和行內(nèi)塊級標(biāo)簽。
特點:
1、在頁面內(nèi)只占據(jù)剛好能包裹自己內(nèi)容的空間
2、沒有寬高,內(nèi)容多大就多大,行內(nèi)標(biāo)簽不能嵌套塊級標(biāo)簽(a標(biāo)簽除外)
3、行內(nèi)標(biāo)簽設(shè)置寬高無效,可以對行高line-height進行設(shè)置
4、可以設(shè)置外邊距margin和內(nèi)邊距padding,但只對左右邊距有效果,上下無效
5、常見行內(nèi)標(biāo)簽span、a、strong、ins、del、br等
span標(biāo)簽
雙標(biāo)簽,行內(nèi)標(biāo)簽,本身沒有固定樣式
<p>我是<span>中國人</span></p>
特點:
1、獨占一行
2、高度、寬度、外邊距、內(nèi)邊距都可以設(shè)置生效
3、寬度默認是父級寬度的100%
4、是一個容器盒子,可以嵌套多層子級行內(nèi)標(biāo)簽、塊級標(biāo)簽,文本類塊級標(biāo)簽除外
5、常見塊級標(biāo)簽div、p、h1~h6、ol、ul、li等
div標(biāo)簽
雙標(biāo)簽,塊級標(biāo)簽,本身沒有固定樣式
<!-- 頭部區(qū)域 -->
<div></div>
<!-- 內(nèi)容區(qū)域 -->
<div></div>
特點
1、在頁面內(nèi)只占據(jù)剛好能包裹自己內(nèi)容的空間
2、高度、寬度、外邊距、內(nèi)邊距都可以設(shè)置生效
3、常見塊級標(biāo)簽img、input、td
通過css樣式display屬性轉(zhuǎn)換,這是css的內(nèi)容
綱
1、什么是<a>標(biāo)簽
2、<a>標(biāo)簽的幾個重要屬性
3、a標(biāo)簽的運行機制
4、a標(biāo)簽常用的協(xié)議
5、超鏈接標(biāo)簽的樣式問題——a標(biāo)簽的偽類選擇器的書寫順序
1、什么是<a>標(biāo)簽
<a> 標(biāo)簽定義超鏈接,用于從一張頁面鏈接到另一張頁面。
<a> 元素最重要的屬性是 href 屬性,它指示鏈接的目標(biāo)。
2、<a>標(biāo)簽的幾個重要屬性
2.1、href
規(guī)定鏈接指向的頁面的 URL。
2.2、target
規(guī)定在何處打開鏈接文檔。
a:自定義打開錨點
target的特殊值:有 4 個保留的目標(biāo)名稱用作特殊的文檔重定向操作:
2.3、name
規(guī)定錨的名稱。(Html5不支持)
2.4、downloadHTML5新增
HTML5新增,只有 Firefox 和 Chrome 支持 download 屬性。
download 屬性規(guī)定被下載的超鏈接目標(biāo)。
在 <a> 標(biāo)簽中必須設(shè)置 href 屬性。
該屬性也可以設(shè)置一個值來規(guī)定下載文件的名稱。所允許的值沒有限制,瀏覽器將自動檢測正確的文件擴展名并添加到文件 (.img, .pdf, .txt, .html, 等等)。
1
<a href="/images/myw3schoolimage.jpg" download="w3logo">
2.5、media
media 屬性規(guī)定目標(biāo) URL 是為什么類型的媒介/設(shè)備進行優(yōu)化的。
該屬性用于規(guī)定目標(biāo) URL 是為特殊設(shè)備(比如 iPhone)、語音或打印媒介設(shè)計的。
該屬性可接受多個值。
只能在 href 屬性存在時使用。
3、a標(biāo)簽的運行機制
4、a標(biāo)簽常用的協(xié)議
5、超鏈接標(biāo)簽的樣式問題——a標(biāo)簽的偽類選擇器的書寫順序
5.1、a標(biāo)簽的多重狀態(tài)
對于<a>元素,我們可以用“多重人格”來形容它。對于該標(biāo)簽,它一共有五種狀態(tài)::link, :visited, :hover, :focus, :active.
“:link”可以用于聲明未訪問狀態(tài)鏈接的樣式;
“:visited”可以用于聲明已經(jīng)訪問鏈接的樣式;
“:hover”可以用于聲明鼠標(biāo)懸停在鏈接上的樣式;
“:focus”可以用于聲明瀏覽器焦點懸停在鏈接上的樣式(通過鍵盤選擇鏈接);
“:active”可以用于聲明瀏覽器點擊鏈接的樣式。
注意:冒號前后不要出現(xiàn)空格
一般a:hover和a:visited鏈接的狀態(tài)(顏色、下劃線等)應(yīng)該是相同的。
link、visited、active分別對應(yīng)body元素的link、vlink、alink這三個屬性。
四個“狀態(tài)”的先后過程是:a:link ->a:hover ->a:active ->a:visited。另外,a:active不能設(shè)置有無下劃線(總是有的)。
5.2、鏈接(a標(biāo)簽狀態(tài))定義的順序
沒有規(guī)矩不成方圓,雖然鏈接定義寫好了,但它也是有規(guī)則的,如果這四項的書寫順序稍有差錯,鏈接的效果可能就沒有了,所以每次定義鏈接樣式時務(wù)必確認定義的順序,link--visited--hover-active,也就是我們常說到的LoVe HAte原則(大寫字母就是它們的首字母)。
老外總結(jié)了一個便于記憶的“愛恨原則”(LoVe/HAte),即四種偽類的首字母:LVHA。定義A鏈接樣式的正確的順序:a:link、a:visited、a:hover、a:active。若沒有按照這樣的順序的話,有的狀態(tài)的樣式會被放置在后面的樣式覆蓋而導(dǎo)致像沒有觸發(fā)一樣沒有效果,如:如果hover放在visited之后,則就算我放上去變色了,但是同時這個標(biāo)簽也具有visited狀態(tài)以及其的效果,會覆蓋了hover的效果。
為了符合瀏覽器解釋CSS遵循的"就近原則"。我們在定義CSS中,宜將最一般的條件放在最上面,并依次向下,最下面放最特殊的。
在W3C規(guī)范中,也規(guī)定了鏈接的聲明順序:
在 CSS 定義中,a:hover 必須被置于 a:link 和 a:visited 之后,才是有效的。
在 CSS 定義中,a:active 必須被置于 a:hover 之后,才是有效的。
我自己是一名從事了多年開發(fā)的web前端老程序員,目前辭職在做自己的web前端私人定制課程,今年年初我花了一個月整理了一份最適合2019年學(xué)習(xí)的web前端學(xué)習(xí)干貨,各種框架都有整理,送給每一位前端小伙伴,想要獲取的可以關(guān)注我的頭條號并在后臺私信我:前端,即可免費獲取。
在前端開發(fā)編寫html文件的時候,我們可能會很熟練的寫出常見的html元素,但是如果問到某些元素的差別時,大家不一定能說的出來,今天就給大家總結(jié)一下那些很常見但容易混淆的屬性。
html與css
css樣式文件引入的方式有兩種,分別是link標(biāo)簽和@import。
link語法結(jié)構(gòu)
link語法結(jié)構(gòu)如下,注意rel='stylesheet'屬性要加上。
link語法結(jié)構(gòu)
@import語法結(jié)構(gòu)
當(dāng)@import用在html中時,需要配合style標(biāo)簽
@import在html中
當(dāng)@import用在css文件中,直接使用@import url()即可
@import在css中
既然link與@import都可以用來引入css,那么它們的區(qū)別是什么呢?我們又該如何選擇呢?
link是XHTML標(biāo)簽的一種,除了可以加載css外,還可以定義其他rel屬性,而@import只能用來加載css。
link標(biāo)簽在加載css時,與頁面一同加載,而@import需要等到網(wǎng)頁完全加載以后才進行加載。
link是XHTML標(biāo)簽,不存在兼容問題,而@import是在CSS2.1中提出的,對于低版本的瀏覽器不支持。
link標(biāo)簽可以通過Javascript代碼去控制其屬性,而@import不可以。
javascript控制link
@import支持在css文件中再次引入其他css文件,方便對多個css文件的管理。
因為@import引入的文件需要在網(wǎng)頁完全加載后再加載,如果在網(wǎng)絡(luò)速度較慢的情況下,會出現(xiàn)頁面閃現(xiàn),因此建議使用link標(biāo)簽代替@import。
html元素的readonly與disabled屬性一般都是用于無法改變表單的內(nèi)容,但是兩者也是有區(qū)別的。
readonly屬性只針對input(text,password)和textarea元素,而disabled適用于所有表單元素,包括select,radio,checkbox,button等。
在表單元素使用了disabled后,該元素的的值不會隨著form的action請求傳遞到服務(wù)器端,而使用readonly的元素值可以傳遞到服務(wù)器端。
以下是一些關(guān)于兩者的使用建議。
在表單中為用戶預(yù)填的唯一標(biāo)識碼,不允許用戶改動,而且需要傳遞到后臺的使用readonly屬性。
用戶提交完表單元素后,等待服務(wù)器端的驗證,這個過程應(yīng)該將元素設(shè)為disabled,button和submit也應(yīng)該設(shè)為disabled,以防止重復(fù)提交。
title屬性
img標(biāo)簽的title屬性是用來提供一些建議性的信息,在鼠標(biāo)停留在上方時會顯示,它對于圖片來說只是一種注釋性的信息,重要性偏低。
alt屬性
alt屬性是為不能顯示圖像時,用來指定替換文字,需要注意的是替換文字是用來代替文字的,而不是用來注釋文字的。
屬性的使用
在做圖片為主的網(wǎng)頁時,考慮到網(wǎng)頁的SEO,應(yīng)當(dāng)設(shè)置圖片的alt屬性為圖片的真實內(nèi)容,而給title設(shè)置一些建議性的內(nèi)容。
今天這篇文章主要將了幾個html中容易混淆的屬性,你有收獲嗎?
*請認真填寫需求信息,我們會在24小時內(nèi)與您取得聯(lián)系。