在互联网中,超链接可谓是无处不在,它是各个网页之间的桥梁,使得网页能够进行跳转。一个网站之中的页面也必须通过超链接连接起来才能称之为网站。
当然,超链接除了指向另一个网页之外,还可以指向邮箱地址、图片、文件等。
向网页中添加a标签是实现超链接的重要方式,但不是唯一方式。本文后面所提到的超链接一般是指通过a标签添加的超链接。
我的码云
以上代码实现了一个超链接,指向一个网页。点击后可以访问连接指向的网页。
在超链接中最主要的属性有三个,分别是:href
、title
、target
。其他一些属性会在后面陆续出现。
href属性用于指示一个目标,该属性是a标签必不可少的,少了它超链接将不能跳转。href属性的值是一个链接,也就是网页或资源的地址。比如:href="https://gitee.com/HeavyLeaf"
,href的值是一个网页的地址。
链接可以是一个完整的地址,也可以是相对路径。对于外部连接通常使用完整的链接,链接必须包含所使用的协议(HTTP,HTTPS等),否则将是一个无效链接。
我的码云
我的码云
上例中,第一个超链接的地址是完整的地址,包含了https
协议,因此该超链接是有效的;第二个超链接的地址个缺少协议类型,因此是无效的超链接。
对于内部链接,通常使用的是相对路径。
我的主页
title
属性可以为超链接设置一些介绍信息。当鼠标移到设置了title
属性的超链接上时,会显示title
属性值的内容。设置了title
不仅可以提升用户体验,还可以提升网页的SEO(搜索引擎优化)。
我的码云
PS:上图中,鼠标其实是悬停在链接上的,截图没有捕获到鼠标。
target
属性用于控制链接网页打开的位置(相对于当前网页)。默认情况下,是刷新当前网页所在的窗口,加载新的页面。
target
属性值及描述:
_self
:默认状态。在当前页面所在窗口打开链接的网页。
_blank
:在当前浏览器中打开一个新窗口加载链接的网页。
_parent
:在父窗口打开链接的网页。(有些页面可以通过等方式打开一些子窗口)
_top
:清除当前窗口中打开的所有框架(子窗口),并在整个窗口打开链接的网页。
framename
:在指定的框架中打开链接的网页。
使用得最最频繁的属性值是_self
和_blank
。至于_parent
、_top
和framename
基本已不再使用。
锚链接可以链接到本页面的特定位置,也可以链接到另一个页面的特定位置。其实现方式是添加锚标记。
当跳转到当前页面的特定位置时,直接将锚标记设为href属性的值。
跳转到本页面的id标记处
当跳转到另一个网页的特定位置时,将锚标记添加到链接地址的末尾。
跳转到另一个页面的标记处
关于“#标记名”,它其实是页面中某一个标签的id
属性值。也就是说,如果要跳转到网页的某个位置,就先在这个位置所在的标签设置id
属性,然后就可以通过锚链接跳转到这个位置了。
跳转
<标签名 id="标记名">标签名>
当href属性的值为一个“#”时,表示该链接是指向页面顶部的,点击后可直接跳转到本页面顶部。
返回顶部
在一些网站上存在一些图片,当点击图片时,就会跳转到另一个页面。这其实是将图片作为了a标签的内容。
在很多网站中,都会有一个可点击的邮箱地址,当点击后,会打开邮箱发送邮件。这其实是将a标签中的href属性值设置为了邮件发送的相关内容。
发送邮件时使用的是mailto:
链接,这类型的连接有几个参数:
[email protected]
:这是第一个参数,也是必填参数。它指的是接收方的邮件地址。
[email protected]
:抄送地址。(可选)
[email protected]
:密送地址。(可选)
subject=subject text
:邮件主题。(可选)
body=body text
:邮件内容。(可选)
?
:第一个参数与第二个参数的分隔符。(可选)
&
:除第一和第二个参数之间的分隔之外的其他参数之间的分隔符。(可选)
下面是一组例子:
[email protected]
[email protected]
[email protected]
[email protected]
[email protected]
总的来说,就是mailto
的第一个参数是必须的,其他参数可以没有,也可以是任意一个或几个的组合。
注意:参数subject
和body
的值不应该直接使用中文和特殊字符以及空格,否则会造成乱码以及一些意想不到的结果。中文和特殊字符应该使用URL编码,如空格使用“%20”代替。
有一些链接在点击后可以下载文件、图片、音视频等,这一类链接称为下载链接。其实现方法是将href
属性的值设为被下载资源的路径,然后再添加download
属性。
下载
下载
在上例中,第一个下载链接的download
属性值为“picture.jpg”,这表示图片下载后命名为“picture.jp”g。当然文件后缀也可以不写。第二个下载链接的download
属性没有属性值,这表明下载后图片的文件名为资源文件的文件名,即“1.jpg”。
a标签有4种伪类选择器:
:link
:超链接未被访问时的状态,也是超链接的初始样式,可以不设置;
:visited
:超链接已被访问的状态;
:hover
:光标悬停在标签上的状态(该伪类不局限于a标签使用);
:active
:光标在标签上被按下时(鼠标单击按下还没释放时)的状态(该伪类不局限与a标签使用);
当不适用这些伪类修改a标签的样式时,标签的默认样式如下:
:link
:蓝色,有下划线;
:visited
:紫色,有下划线;
:hover
:和hover前一样;
:active
:红色,有下划线;
a标签的4个伪类选择器要求遵循顺序::link
→ :visited
→ :hover
→ :active
。
有人会问:为什么一定要遵循这个顺序?不按这个循序行不行?
其实是可以的,但只允许:link
和:visited
交换以下位置。至于为什么,后面会解释。
在CSS样式优先级中有这么一条规则:当样式优先级优先级相同时,后面的样式会覆盖前面的样式。因此,这四种样式需要按照一定的顺序出现,否则会导致某些状态的样式被其他状态样式覆盖的情况。
这四种样式都是在某种行为下被触发的。这些行为是:未访问过(:link
)、访问过(:visited
)、光标悬停(:hover
)和光标按下(:active
)。
首先,一个超链接要么已经访问过,要么未访问过,因此访问过与未访问过两种状态不可能同时存在,因此:link
和:visited
的先后顺序可以随意。但从逻辑上,链接是先未访问过,然后到已访问过的。所以顺序应该先:link
,后:visited
。
当光标移动到标签上时,标签的:hover伪
类样式将被激活,覆盖:link
或:visited
的样式。因此:hover
应该在:link
和:visited
之后,否则:hover
的样式将被覆盖,无法显示。此时伪类选择器的顺序是::link
→ :visited
→ :hover
。
当鼠标按下时,标签的:active
伪类样式被激活。这时光标是停留在标签上的,而且是未访问或已访问的状态。因此,为了能够样:active
样式能够正常的显示出来,:active
应该将:hover
、:visited
、:link
的样式覆盖。这时就可以得出四个伪类选择器的顺序就是::link
→ :visited
→ :hover
→ :active
。