欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

HTML5中的A 標(biāo)簽詳解

  發(fā)布時(shí)間:2024-05-28 17:29:51   作者:DonV   我要評(píng)論
a 元素可通過(guò)其href屬性創(chuàng)建指向其他網(wǎng)頁(yè)、文件、同一頁(yè)面內(nèi)的位置或其他URL的超鏈接,這篇文章主要介紹了HTML5中的A 標(biāo)簽,需要的朋友可以參考下

概述

a 元素可通過(guò)其href屬性創(chuàng)建指向其他網(wǎng)頁(yè)、文件、同一頁(yè)面內(nèi)的位置或其他URL的超鏈接。

其基本屬性及含義如下。

  • href:鏈接目標(biāo)的URL
  • hreflang:指定目標(biāo)URL的語(yǔ)言
  • rel:指定當(dāng)前文檔和被鏈接文檔的關(guān)系
  • target:指定打開(kāi)目標(biāo)URL的方式
  • media:指定目標(biāo)URL的媒體類型
  • type:指定目標(biāo)URLMIME 類型
  • download:指示瀏覽器下載URL

鏈接樣式

在瀏覽器中a標(biāo)簽的默認(rèn)樣式帶有下劃線,其狀態(tài)和顏色如下。

  • link:未訪問(wèn)狀態(tài),字體顏色為藍(lán)色
  • visited:已訪問(wèn)狀態(tài),字體顏色為紫色
  • hover:鼠標(biāo)懸停狀態(tài)
  • active:鼠標(biāo)點(diǎn)擊時(shí)狀態(tài),字體顏色為紅色
  • focus:聚焦時(shí)的狀態(tài),可通過(guò)Tab鍵聚焦元素,聚焦時(shí)會(huì)出現(xiàn)邊框(不同瀏覽器樣式不一致)
<a >百度</a>

可通過(guò)偽類自定義不同狀態(tài)的樣式,注意linkvisited必須在最前面,且沒(méi)有先后順序,而focushoveractive 必須在后面,并且一定是focus、hover、active的順序。

首先靜態(tài)時(shí)(元素未被聚焦、鼠標(biāo)點(diǎn)擊或懸?。?,a標(biāo)簽只能為未訪問(wèn)和已訪問(wèn)狀態(tài)中的一種,進(jìn)而只會(huì)命中linkvisited偽類中的一種,另一種不會(huì)生效,因此linkvisited沒(méi)有先后順序。

而在動(dòng)態(tài)時(shí)(比如鼠標(biāo)懸?。?,a標(biāo)簽此時(shí)的樣式應(yīng)該是呈現(xiàn)懸浮的樣式,由于偽類的權(quán)重都是一樣的,因此hover偽類的樣式必然要位于linkvisited后面,才能覆蓋其樣式。

可以通過(guò)Tab鍵聚焦a標(biāo)簽,聚焦后,若鼠標(biāo)懸浮在標(biāo)簽上,此時(shí)則需要呈現(xiàn)懸浮的樣式,因此hover位于focus后面。

而在a標(biāo)簽被懸浮時(shí),若此時(shí)點(diǎn)擊鼠標(biāo)不松開(kāi),則此時(shí)需要呈現(xiàn)點(diǎn)擊的樣式,因此active位于hover后面。

所以偽類順序只能為link、visited、focus、hoveractive或者visited、linkfocus、hoveractive兩種。

a:link {
  color: pink;
}
a:visited {
  color: orange;
}
a:focus {
  color: blue;
}
a:hover {
  color: red;
}
a:active {
  color: green;
}

指定鏈接打開(kāi)方式

target用于指定鏈接的打開(kāi)方式,包括如下四種。

  • _self:當(dāng)前頁(yè)面打開(kāi)鏈接
  • _blank:新窗口打開(kāi)鏈接
  • _parent:在當(dāng)前框架的父框架打開(kāi)頁(yè)面
  • _top:在當(dāng)前框架的頂層框架打開(kāi)頁(yè)面

如下為main.htmltop.html、center.htmlleft.htmlright.html的頁(yè)面結(jié)構(gòu),其中main.html通過(guò)iframe方式引入top.htmlcenter.html,center.html也通過(guò)iframe方式引入left.htmlright.html。

頁(yè)面部分代碼如下。

// 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.htmla標(biāo)簽的target_self,單擊a標(biāo)簽。

可以看到在right.html框架中打開(kāi)了百度,即在自身頁(yè)面中單擊target_self屬性的鏈接,將在本頁(yè)面框架中打開(kāi)目標(biāo)頁(yè)面。

_parant

修改right.htmla標(biāo)簽的target_parent,單擊a標(biāo)簽。

可以看到在center.html框架中打開(kāi)了百度,即在自身頁(yè)面中單擊target_parent屬性的鏈接,將在本頁(yè)面的父框架中打開(kāi)目標(biāo)頁(yè)面。

_top

修改right.htmla標(biāo)簽的target_top,單擊a標(biāo)簽。

可以看到在main.html框架中打開(kāi)了百度,即在自身頁(yè)面中單擊target_top屬性的鏈接,將在本頁(yè)面的頂層框架中打開(kāi)目標(biāo)頁(yè)面。

_blank

_blank則是打開(kāi)一個(gè)新標(biāo)簽頁(yè)顯示目標(biāo)頁(yè)面。

錨點(diǎn)

頁(yè)面內(nèi)跳轉(zhuǎn),如下將跳轉(zhuǎn)至本頁(yè)面的h1錨點(diǎn)位置。

<a href="#h1">a</a>
<h1 id="h1">h1<h1>

跳轉(zhuǎn)至其他頁(yè)面的指定位置,如下將跳轉(zhuǎn)至other.html頁(yè)面中的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ā)送短信DX10086,注意安卓系統(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);隔開(kāi)
  • cc:抄送人員郵箱地址,多人使用分號(hào);隔開(kāi)
  • bcc:密送人員郵箱地址,多人使用分號(hào);隔開(kāi)
  • 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)如下。

  • 瀏覽器不能直接打開(kāi)的文件(如txt、zip等),不指定download屬性也會(huì)直接下載
  • 瀏覽器可以直接打開(kāi)的文件(如png、cssjs、html等),需指定download屬性才能下載
  • download屬性值可以不指定后綴名,下載時(shí)瀏覽器會(huì)自動(dòng)補(bǔ)充
  • download屬性值指定了錯(cuò)誤的后綴名,文件下載后將無(wú)法打開(kāi)預(yù)覽

同源策略

由于瀏覽器的 同源策略 限制,若下載的文件與頁(yè)面不同源,瀏覽器不會(huì)執(zhí)行下載而是直接打開(kāi),更多 詳細(xì)參考。

如下若頁(yè)面地址為http://127.0.0.1:3000,點(diǎn)擊a標(biāo)簽將不會(huì)下載而是在瀏覽器打開(kāi)。

<a  download>baidu</a>

data:URLs

如下使用data:URLs的方式下載圖片,首先通過(guò)canvas繪制圖片,然后再使用canvas.toDataURL獲取圖片base64編碼,最后再通過(guò)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()了。imgform等支持跨域的標(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",不攜帶任何用戶信息來(lái)獲取圖片。

blob:URLs

如下使用blob:URLs的方式下載圖片,通過(guò)使用canvas.toBlob獲取到blob對(duì)象,然后再通過(guò)URL.createObjectURL獲取到blob對(duì)象的一個(gè)內(nèi)存URL,并且一直存儲(chǔ)在內(nèi)存中,直到document觸發(fā)了unload事件或者執(zhí)行revokeObjectURL來(lái)釋放。

<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等則不行。

可以通過(guò)ajax方式請(qǐng)求到文件的blob數(shù)據(jù),再通過(guò)blob:URLs的方式下載。

注意ajax請(qǐng)求方式會(huì)存在跨域問(wèn)題,需要服務(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)文章

  • HTML5中的Microdata與歷史記錄管理詳解

    Microdata作為HTML5新增的一個(gè)特性,它允許開(kāi)發(fā)者在HTML文檔中添加更多的語(yǔ)義信息,以便于搜索引擎和瀏覽器更好地理解頁(yè)面內(nèi)容,本文將探討HTML5中Microdata的使用方法以及
    2025-04-21
  • HTML5表格語(yǔ)法格式詳解

    在HTML語(yǔ)法中,表格主要通過(guò)< table >、< tr >和< td >3個(gè)標(biāo)簽構(gòu)成,本文通過(guò)實(shí)例代碼講解HTML5表格語(yǔ)法格式,感興趣的朋友一起看看吧
    2025-04-21
  • html5的響應(yīng)式布局的方法示例詳解

    這篇文章主要介紹了HTML5中使用媒體查詢和Flexbox進(jìn)行響應(yīng)式布局的方法,簡(jiǎn)要介紹了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展示,通過(guò)Canvas的API,可以繪制出6個(gè)不同城市的時(shí)鐘,并且這些時(shí)鐘可以動(dòng)態(tài)轉(zhuǎn)動(dòng),每個(gè)時(shí)鐘上都會(huì)標(biāo)注出對(duì)應(yīng)的
    2025-03-11
  • HTML5 data-*自定義數(shù)據(jù)屬性的示例代碼

    HTML5的自定義數(shù)據(jù)屬性(data-*)提供了一種標(biāo)準(zhǔn)化的方法在HTML元素上存儲(chǔ)額外信息,可以通過(guò)JavaScript訪問(wèn)、修改和在CSS中使用,文章還介紹了高級(jí)用法,如存儲(chǔ)JSON數(shù)據(jù)、事
    2025-03-11
  • HTML5中下拉框<select>標(biāo)簽的屬性和樣式詳解

    在HTML5中,下拉框(<select>標(biāo)簽)作為表單的重要組成部分,為用戶提供了一個(gè)從預(yù)定義選項(xiàng)中選擇值的方式,本文將深入探討<select>標(biāo)簽的屬性、樣式,并重點(diǎn)介
    2025-02-27
  • HTML5 Input 日期選擇器詳解

    本文介紹了HTML5InputDatePicker對(duì)象表示HTML``元素,是HTML5中的新對(duì)象,介紹了日期、周、月份、時(shí)間、日期+時(shí)間、本地日期時(shí)間等不同類型的日期選擇器,感興趣的朋友一起看
    2025-02-17
  • HTML5超鏈接和圖片基礎(chǔ)用法詳解

    本文介紹了HTML5中的超鏈接、相對(duì)路徑和圖片的使用方法,超鏈接可以創(chuàng)建指向另一個(gè)文檔或頁(yè)面內(nèi)部書簽的鏈接,相對(duì)路徑用于在同一服務(wù)器內(nèi)部跳轉(zhuǎn)頁(yè)面,圖片標(biāo)簽用于引入外部圖
    2025-02-17
  • HTML5超鏈接的創(chuàng)建方法

    本文介紹了HTML5超鏈接的創(chuàng)建方法,包括基本語(yǔ)法、創(chuàng)建圖像超鏈接的邊框去除方法以及錨點(diǎn)鏈接的使用,還討論了超鏈接的四種不同狀態(tài)(link、visited、hover、active)的CSS樣
    2025-02-17
  • HTML5使用details標(biāo)簽:展開(kāi)/收縮信息

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

最新評(píng)論