HTML5中的A 標(biāo)簽詳解
概述
a 元素可通過其href屬性創(chuàng)建指向其他網(wǎng)頁、文件、同一頁面內(nèi)的位置或其他URL的超鏈接。
其基本屬性及含義如下。
href:鏈接目標(biāo)的URLhreflang:指定目標(biāo)URL的語言rel:指定當(dāng)前文檔和被鏈接文檔的關(guān)系target:指定打開目標(biāo)URL的方式media:指定目標(biāo)URL的媒體類型type:指定目標(biāo)URL的 MIME 類型download:指示瀏覽器下載URL
鏈接樣式
在瀏覽器中a標(biāo)簽的默認(rèn)樣式帶有下劃線,其狀態(tài)和顏色如下。
link:未訪問狀態(tài),字體顏色為藍(lán)色visited:已訪問狀態(tài),字體顏色為紫色hover:鼠標(biāo)懸停狀態(tài)active:鼠標(biāo)點(diǎn)擊時(shí)狀態(tài),字體顏色為紅色focus:聚焦時(shí)的狀態(tài),可通過Tab鍵聚焦元素,聚焦時(shí)會(huì)出現(xiàn)邊框(不同瀏覽器樣式不一致)
<a >百度</a>
可通過偽類自定義不同狀態(tài)的樣式,注意link和visited必須在最前面,且沒有先后順序,而focus、hover和active 必須在后面,并且一定是focus、hover、active的順序。
首先靜態(tài)時(shí)(元素未被聚焦、鼠標(biāo)點(diǎn)擊或懸浮),a標(biāo)簽只能為未訪問和已訪問狀態(tài)中的一種,進(jìn)而只會(huì)命中link和visited偽類中的一種,另一種不會(huì)生效,因此link和visited沒有先后順序。
而在動(dòng)態(tài)時(shí)(比如鼠標(biāo)懸?。?code>a標(biāo)簽此時(shí)的樣式應(yīng)該是呈現(xiàn)懸浮的樣式,由于偽類的權(quán)重都是一樣的,因此hover偽類的樣式必然要位于link和visited后面,才能覆蓋其樣式。
可以通過Tab鍵聚焦a標(biāo)簽,聚焦后,若鼠標(biāo)懸浮在標(biāo)簽上,此時(shí)則需要呈現(xiàn)懸浮的樣式,因此hover位于focus后面。
而在a標(biāo)簽被懸浮時(shí),若此時(shí)點(diǎn)擊鼠標(biāo)不松開,則此時(shí)需要呈現(xiàn)點(diǎn)擊的樣式,因此active位于hover后面。
所以偽類順序只能為link、visited、focus、hover、active或者visited、link、focus、hover、active兩種。
a:link {
color: pink;
}
a:visited {
color: orange;
}
a:focus {
color: blue;
}
a:hover {
color: red;
}
a:active {
color: green;
}指定鏈接打開方式
target用于指定鏈接的打開方式,包括如下四種。
_self:當(dāng)前頁面打開鏈接_blank:新窗口打開鏈接_parent:在當(dāng)前框架的父框架打開頁面_top:在當(dāng)前框架的頂層框架打開頁面
如下為main.html、top.html、center.html、left.html和right.html的頁面結(jié)構(gòu),其中main.html通過iframe方式引入top.html和center.html,center.html也通過iframe方式引入left.html和right.html。

頁面部分代碼如下。
// main.html
<head>
<style>
body {
width: 1500px;
margin: 10px auto;
display: flex;
flex-direction: column;
}
iframe {
width: 100%;
}
</style>
</head>
<body>
<iframe src="top.html" frameborder="0" height="300px"></iframe>
<iframe src="center.html" frameborder="0" height="600px"></iframe>
</body>
// top.html
<head>
<style>
body {
width: 100%;
height: 300px;
margin: 0;
background-color: #FF952C;
}
</style>
</head>
<body></body>
// center.html
<head>
<style>
body {
height: 600px;
background-color: #FFCC00;
display: flex;
margin: 0;
}
iframe {
height: 500px;
}
</style>
</head>
<body>
<iframe src="left.html" frameborder="0" style="width: 200px;"></iframe>
<iframe src="right.html" frameborder="0" style="width: 1300px"></iframe>
</body>
// left.html
<head>
<style>
body {
margin: 0;
width: 100%;
height: 500px;
background-color: #02BF0F;
}
</style>
</head>
<body></body>
// right.html
<head>
<style>
body {
margin: 0;
width: 100%;
height: 500px;
background-color: #2196F3;
}
</style>
</head>
<body>
<a target="_self" style="color: #fff;text-decoration: none;">百度</a>
</body>_self
修改right.html中a標(biāo)簽的target為_self,單擊a標(biāo)簽。
可以看到在right.html框架中打開了百度,即在自身頁面中單擊target為_self屬性的鏈接,將在本頁面框架中打開目標(biāo)頁面。

_parant
修改right.html中a標(biāo)簽的target為_parent,單擊a標(biāo)簽。
可以看到在center.html框架中打開了百度,即在自身頁面中單擊target為_parent屬性的鏈接,將在本頁面的父框架中打開目標(biāo)頁面。

_top
修改right.html中a標(biāo)簽的target為_top,單擊a標(biāo)簽。
可以看到在main.html框架中打開了百度,即在自身頁面中單擊target為_top屬性的鏈接,將在本頁面的頂層框架中打開目標(biāo)頁面。

_blank
_blank則是打開一個(gè)新標(biāo)簽頁顯示目標(biāo)頁面。
錨點(diǎn)
頁面內(nèi)跳轉(zhuǎn),如下將跳轉(zhuǎn)至本頁面的h1錨點(diǎn)位置。
<a href="#h1">a</a> <h1 id="h1">h1<h1>
跳轉(zhuǎn)至其他頁面的指定位置,如下將跳轉(zhuǎn)至other.html頁面中的p錨點(diǎn)位置。
<a href="other.html#p">a</a>
電話
撥打10086。
<a href="tel:10086">10086</a>
撥打客服電話400。
<a href="tel:400-888-8888">400-888-8888</a>
短信
發(fā)送短信至單個(gè)號(hào)碼。
<a href="sms:10086">10086</a>
發(fā)送短信至多個(gè)號(hào)碼。
<a href="sms:10086,10000">10086,10000</a>
發(fā)送短信DX到10086,注意安卓系統(tǒng)使用?連接發(fā)送內(nèi)容,IOS系統(tǒng)使用&連接發(fā)送內(nèi)容。
由于不同手機(jī)廠商或?yàn)g覽器廠商對(duì)此標(biāo)準(zhǔn)支持度不同,最好還是不帶body。
<a href="sms:10086?body=DX">DX</a>
郵箱
發(fā)送單個(gè)郵箱。
<a href="mailto:xxx@email.com">email</a>
發(fā)送多個(gè)郵箱。???????
<a href="mailto:xxx@email.com; xx@email.com">email</a>
mailto相關(guān)參數(shù)如下。
mailto:收件人郵箱地址,若有多個(gè)收件人郵件地址,用分號(hào);隔開cc:抄送人員郵箱地址,多人使用分號(hào);隔開bcc:密送人員郵箱地址,多人使用分號(hào);隔開subject:郵件主題body:郵件內(nèi)容
??<a href="mailto:xxx@email.com?cc=cc@email.com&bcc=bcc@email.com&subject=subject&body=body">email</a>
下載文件
下載圖片,其中href為圖片路徑。
<a href="./image.png" download>image</a>
下載圖片并指定下載名。
<a href="./image.png" download="name.png">image</a>
download屬性注意事項(xiàng)如下。
- 瀏覽器不能直接打開的文件(如
txt、zip等),不指定download屬性也會(huì)直接下載 - 瀏覽器可以直接打開的文件(如
png、css、js、html等),需指定download屬性才能下載 download屬性值可以不指定后綴名,下載時(shí)瀏覽器會(huì)自動(dòng)補(bǔ)充download屬性值指定了錯(cuò)誤的后綴名,文件下載后將無法打開預(yù)覽
同源策略
由于瀏覽器的 同源策略 限制,若下載的文件與頁面不同源,瀏覽器不會(huì)執(zhí)行下載而是直接打開,更多 詳細(xì)參考。
如下若頁面地址為http://127.0.0.1:3000,點(diǎn)擊a標(biāo)簽將不會(huì)下載而是在瀏覽器打開。
<a download>baidu</a>
data:URLs
如下使用data:URLs的方式下載圖片,首先通過canvas繪制圖片,然后再使用canvas.toDataURL獲取圖片base64編碼,最后再通過a標(biāo)簽完成下載。
<a href="javascript:void(0);" onclick="downloadFile(event)" src='https://www.baidu.com/logo.png'>download</a>
<script>
function downloadFile(e) {
const url = e.target.getAttribute('src')
const image = new Image()
image.setAttribute('crossOrigin', 'anonymous')
image.src = url
image.onload = () => {
const canvas = document.createElement('canvas')
const ctx = canvas.getContext('2d')
canvas.width = image.width
canvas.height = image.height
ctx.drawImage(image, 0, 0, image.width, image.height)
const ext = image.src.substring(image.src.lastIndexOf('.') + 1).toLowerCase()
const name = image.src.substring(image.src.lastIndexOf('/') + 1)
const dataURL = canvas.toDataURL('image/' + ext)
const a = document.createElement('a')
a.href = dataURL
a.download = name
a.click()
}
}
</script>注意不設(shè)置crossOrigin,瀏覽器將會(huì)拋出如下錯(cuò)誤。

其原因也是瀏覽器的同源策略導(dǎo)致,canvas繪制跨域請(qǐng)求的圖片,就會(huì)造成畫布污染,此時(shí)也就不能再調(diào)用toBlob()、toDataURL()和getImageData()了。img、form等支持跨域的標(biāo)簽,請(qǐng)求獲取資源時(shí)會(huì)自動(dòng)帶上cookie,如果不做數(shù)據(jù)讀取限制,則cookie數(shù)據(jù)將被上傳到圖片網(wǎng)站后臺(tái)進(jìn)而導(dǎo)致數(shù)據(jù)泄露。
因此可以在圖片請(qǐng)求發(fā)起時(shí)增加crossOrigin="anonymous",不攜帶任何用戶信息來獲取圖片。
blob:URLs
如下使用blob:URLs的方式下載圖片,通過使用canvas.toBlob獲取到blob對(duì)象,然后再通過URL.createObjectURL獲取到blob對(duì)象的一個(gè)內(nèi)存URL,并且一直存儲(chǔ)在內(nèi)存中,直到document觸發(fā)了unload事件或者執(zhí)行revokeObjectURL來釋放。
<a href="javascript:void(0);" onclick="downloadFile(event)" src='https://www.baidu.com/logo.png'>download</a>
<script>
function downloadFile(e) {
const url = e.target.getAttribute('src')
const image = new Image()
image.setAttribute('crossOrigin', 'anonymous')
image.src = url
image.onload = () => {
const canvas = document.createElement('canvas')
const ctx = canvas.getContext('2d')
const name = image.src.substring(image.src.lastIndexOf('/') + 1)
canvas.width = image.width
canvas.height = image.height
ctx.drawImage(image, 0, 0, image.width, image.height)
canvas.toBlob(blob => {
const url = window.URL.createObjectURL(blob)
const a = document.createElement('a')
a.href = url
a.download = name
a.click()
a.remove()
window.URL.revokeObjectURL(url)
})
}
}
</script>ajax
上述兩種方式只對(duì)圖片適用,對(duì)于pdf或者txt等則不行。
可以通過ajax方式請(qǐng)求到文件的blob數(shù)據(jù),再通過blob:URLs的方式下載。
注意ajax請(qǐng)求方式會(huì)存在跨域問題,需要服務(wù)器支持。
<a href="javascript:void(0);" onclick="downloadFile(event)" src='http://www.baidu.com/txt.txt'>download</a>
<script>
function downloadFile(e) {
const url = e.target.getAttribute('src')
const name = url.substring(url.lastIndexOf('/') + 1)
axios.get(url, { responseType: 'blob' }).then(res => {
const blob = res.data
const url = URL.createObjectURL(blob)
const a = document.createElement('a')
a.href = url
a.download = name
a.click()
a.remove()
window.URL.revokeObjectURL(url)
})
}
</script>到此這篇關(guān)于HTML5中的A 標(biāo)簽的文章就介紹到這了,更多相關(guān)HTML5 A 標(biāo)簽內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持腳本之家!
相關(guān)文章
- Microdata作為HTML5新增的一個(gè)特性,它允許開發(fā)者在HTML文檔中添加更多的語義信息,以便于搜索引擎和瀏覽器更好地理解頁面內(nèi)容,本文將探討HTML5中Microdata的使用方法以及2025-04-21
在HTML語法中,表格主要通過< table >、< tr >和< td >3個(gè)標(biāo)簽構(gòu)成,本文通過實(shí)例代碼講解HTML5表格語法格式,感興趣的朋友一起看看吧2025-04-21- 這篇文章主要介紹了HTML5中使用媒體查詢和Flexbox進(jìn)行響應(yīng)式布局的方法,簡要介紹了CSS Grid布局的基礎(chǔ)知識(shí)和如何實(shí)現(xiàn)自動(dòng)換行的網(wǎng)格布局,感興趣的朋友一起看看吧2025-04-21

基于Canvas的Html5多時(shí)區(qū)動(dòng)態(tài)時(shí)鐘實(shí)戰(zhàn)代碼
本文介紹了如何使用Canvas在HTML5上實(shí)現(xiàn)一個(gè)多時(shí)區(qū)動(dòng)態(tài)時(shí)鐘的web展示,通過Canvas的API,可以繪制出6個(gè)不同城市的時(shí)鐘,并且這些時(shí)鐘可以動(dòng)態(tài)轉(zhuǎn)動(dòng),每個(gè)時(shí)鐘上都會(huì)標(biāo)注出對(duì)應(yīng)的2025-03-11HTML5 data-*自定義數(shù)據(jù)屬性的示例代碼
HTML5的自定義數(shù)據(jù)屬性(data-*)提供了一種標(biāo)準(zhǔn)化的方法在HTML元素上存儲(chǔ)額外信息,可以通過JavaScript訪問、修改和在CSS中使用,文章還介紹了高級(jí)用法,如存儲(chǔ)JSON數(shù)據(jù)、事2025-03-11HTML5中下拉框<select>標(biāo)簽的屬性和樣式詳解
在HTML5中,下拉框(<select>標(biāo)簽)作為表單的重要組成部分,為用戶提供了一個(gè)從預(yù)定義選項(xiàng)中選擇值的方式,本文將深入探討<select>標(biāo)簽的屬性、樣式,并重點(diǎn)介2025-02-27
本文介紹了HTML5InputDatePicker對(duì)象表示HTML``元素,是HTML5中的新對(duì)象,介紹了日期、周、月份、時(shí)間、日期+時(shí)間、本地日期時(shí)間等不同類型的日期選擇器,感興趣的朋友一起看2025-02-17
本文介紹了HTML5中的超鏈接、相對(duì)路徑和圖片的使用方法,超鏈接可以創(chuàng)建指向另一個(gè)文檔或頁面內(nèi)部書簽的鏈接,相對(duì)路徑用于在同一服務(wù)器內(nèi)部跳轉(zhuǎn)頁面,圖片標(biāo)簽用于引入外部圖2025-02-17- 本文介紹了HTML5超鏈接的創(chuàng)建方法,包括基本語法、創(chuàng)建圖像超鏈接的邊框去除方法以及錨點(diǎn)鏈接的使用,還討論了超鏈接的四種不同狀態(tài)(link、visited、hover、active)的CSS樣2025-02-17

HTML5使用details標(biāo)簽:展開/收縮信息
最近看一些技術(shù)網(wǎng)站發(fā)現(xiàn)了details 標(biāo)簽的妙用,這個(gè)不用js即可實(shí)現(xiàn)展開/收縮信息,很方便用來讓用戶先才答案,然后下面點(diǎn)擊再給出答案的效果,這里就為大家簡單介紹一下,2024-11-03






