概念

 <a>元素 (或HTML锚元素, Anchor Element)通常用来表示一个锚点/链接。但严格来说,<a>元素不是一个链接,而是超文本锚点,可以链接到一个新文件、用id属性指向任何元素。如果没有<a>元素没有href属性的话,可以作为原本链接位置的占位符,常用于home链接

  [注意]任何文档流内容都可以被嵌套,只要不是交互内容类别(如按钮、链接等)

属性

href

  href属性表示地址,共包括以下3种:

  1、链接地址

  1. <a href="http://www.baidu.com">百度</a>

  2、下载地址

  1. <a href="test.zip">下载测试</a>

  3、锚点

    (1)href:#id名

  1. <a href="#test">目录</a>
  2. <br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br>
  3. <div id="test" style="height: 200px;width: 200px; border: 1px solid black;margin-bottom: 300px;">内容</div>

    (2)href:页面地址#id名

  1. <a href="http://baike.baidu.com/view/2202.htm#2">足球比赛规则</a>

  [注意]href属性一定不要留空,若暂时不需要写地址,则写#或javascript:;。若href留空,会刷新页面

href与src的区别

    href(hypertext reference)指超文本引用,表示当前页面引用了别处的内容

    src(source)表示来源地址,表示把别处的内容引入到当前页面

    所以<img>、<script>、<iframe>等应该使用src,而<a>和<map>应该使用href

  4、手机号码

  在移动端,使用<a href="tel:15012345678>15012345678</a>可以唤出手机拨号盘

target

  target属性表示链接打开方式

  1、_self    当前窗口(默认)
      2、_blank    新窗口
      3、_parent 父框架集
      4、_top 整个窗口
      5、_framename 指定框架

  1. //外层框架
  2. <frameset cols = "20%, *">
  3. <frame src="left.html">
  4. <frame src="right.html">
  5. </frameset>
  6.  
  7. //里层框架
  8. <frameset rows = "50%,*">
  9. <frame src="top.html">
  10. <frame src="bottom.html" name="bottom">
  11. </frameset>
  12.  
  13. //锚点页
  14. <ul class="list">
  15. <li class="in"><a href="chap1.html" target="_self">chap1(_self)</a></li>
  16. <li class="in"><a href="chap2.html" target="_blank">chap2(_blank)</a></li>
  17. <li class="in"><a href="chap3.html" target="_parent">chap3(_parent)</a></li>
  18. <li class="in"><a href="chap4.html" target="_top">chap4(_top)</a></li>
  19. <li class="in"><a href="chap5.html" target="bottom">chap5(framename)</a></li>
  20. </ul>

download

  download属性用来设置下载文件的名称(firefox/chrome/opera支持)

  1. <a href="test.zip" download="gogo">test</a>

rel

  rel属性表示表示链接间的关系

  1. alternate 相较于当前文档可替换的呈现
  2. author 链接到当前文档或文章的作者
  3. bookmark 链接最近的父级区块的永久链接
  4. help 与当前上下文相关的帮助链接
  5. license 当前文档的许可证
  6. next 后一篇文档
  7. prev 前一篇文档
  8. nofollow 当前文档的原始作者不推荐超链接指向的文档
  9. noreferer 访问时链接时不发送referer字段
  10. prefetch 预加载链接指向的页面(对于chrome使用prerender)
  11. search 用于搜索当前文档或相关文档的资源
  12. tag 给当前文档打上标签

  【应用】当一篇篇幅很长的文章需要多页显示时,配合next或prev可以实现前后页面导航的预加载

  1. <a href="prev.html" rel="prev prefetch prerender">前一页</a>
  2. <a href="next.html" rel="next prefetch prerender">后一页</a>
  3. //当然prefetch也可以用于预加载其他类型的资源
  4. <link rel="prefetch prerender" href="test.img">

注意事项

  1、<a>标签的文本颜色只能自身进行设置,从父级继承不到

2、<a>标签的下划线颜色跟随文本颜色进行变化

  3、<a>标签不可嵌套<a>标签

  1. <div style="color: red;">
  2. <a href="#">[]从父级继承不到红色字体</a>
  3. <br>
  4. <a href="#" style="color: green">[]下划线颜色与文本同色</a>
  5. <br>
  6. <a href="#">前面<a href="#">[]a标签不可嵌套</a></a>
  7. </div>

了解HTML锚点的更多相关文章

  1. 原生js模拟锚点,实现点击后,内容定位到本页的对应位置

    今天在做angularJS项目过程中,遇见了一个需求,在一个页面中有多个表格,每个表格都有对应的分页,点击顶部对应的模块,可以定位到每个表格模块具体的位置. 页面如下所示: 在angular中,为了使 ...

  2. angularjs 锚点操作服务 $anchorScroll

    在普通的html网页中,我们可以通过在url后边添加  #elementid 的方式,将页面显示定位到某个元素,也就是锚点. 但是在angularjs应用的网页中,页面路由的写法是 #route/ro ...

  3. js做通讯录的索引滑动显示效果和滑动显示锚点效果

    只做实现..完全没考虑性能优化.所以我实现了以后特别卡. 第一个是在通讯录右边的索引条上进行滑动,滑动到相应字母就跳转到相应字母的锚点上. 思路:监听touchmove事件,获取clientX和cli ...

  4. jQuery实现页面内锚点平滑跳转

    平时我们做导航滚动到内容都是通过锚点来做,刷的一下就直接跳到内容了,没有一丝的滚动效果,而且 url 链接最后会有“小尾巴”,就像#keleyi,今天我就介绍一款 jquery 做的滚动的特效,既可以 ...

  5. JQuery 实现锚点链接之间的平滑滚动

    24. 解决链接锚点的生硬问题 $('.nav .btn[href*=#],.icon2,.icon3').click(function() { if (location.pathname.repla ...

  6. a 锚点跳转滑动效果

    点击a链接时,跳转到相应id的位置处,有一个滑动效果. <a href="#my">我是跳转到div</a><div id="my" ...

  7. HTML meta锚点跳转 小tips

    小tips meta锚点跳转 http://www.zhangxinxu.com/wordpress/2015/03/meta-http-equiv-refresh-content/

  8. Html锚点定位偏差计算解决插件

    /*=============== 以下为HTML中的锚点代码 =====================*/ <div id="fixedNavBar" class=&qu ...

  9. 讨论SEO中是锚文本有效,还是纯文本有效呢?

    现在很多SEO好友不断在讨论,在SEO优化中,到底是锚文本有效,还是纯文本有效呢? 在这里给大家举一下列子:如“张家口人才网”这样的就叫做锚文本,意思是在原有的文本中加上超级链接,指向到优化的网页上面 ...

随机推荐

  1. PHP浮点数精度问题

    这一段时间维护一个类似团购的系统,需要处理订单,也就难免会处理金额 所以有很多PHP的坑 被我狠狠的踩了~~ 首先我们要知道浮点数的表示(IEEE 754): 简言之 就是 埋下了一个大坑 等着你跳 ...

  2. Android -- 软键盘

    1. 应用启动后,自动打开软键盘 InputMethodManager imm = (InputMethodManager) getSystemService(Context.INPUT_METHOD ...

  3. 【验证】C# dataSource 的记忆功能

    做项目时遇到的问题:dataSource被ComboBox引用过一次,会记忆最后一次选中的值,然后下一次再用时这个值会直接呈现在ComboBox中. 为验证是dataSource还是ComboBox自 ...

  4. 模块化管理工具兼打包工具 webpack

    webpack 是一个[模块化管理工具]兼[打包工具] 是一个工具(和seajs,requirejs管理前端模块的方式是不一样) 在webpack一个文件就是一个模块! seajs,requirejs ...

  5. HTML5 与 CSS3 jQuery部分知识总结【转】

    一.    HTML5 为什么需要HTML5 什么是HTML5 HTML5现状及浏览器支持 HTML5优点与缺点 HTML5语法规则与文档声明 HTML5新增表达标签 HTML5多媒体组件 HTML5 ...

  6. storm 入门原理介绍

    1.hadoop有master与slave,Storm与之对应的节点是什么? 2.Storm控制节点上面运行一个后台程序被称之为什么? 3.Supervisor的作用是什么? 4.Topology与W ...

  7. 安卓手机USB网络共享,电脑卡顿、反应慢

    1.首先需要把手机连接到电脑,在手机上打开USB网络共享. 2.打开设备管理器 3.在网络适配器中,找到Remote NDIS based Internet Sharing Device,右键更新驱动 ...

  8. PHP:函数赋参数默认初值

    函数的默认参数 允许定义函数时,指定参数的默认值,如: function js_location($url, $alert='', $top=''){ if($alert=='' && ...

  9. HTML/CS3相关面试题目

    一.HTML/CS3基本面试题目. 1. 常用那几种浏览器测试? 1.1浏览器:IE,Chrome(谷歌),FireFox(火狐),Safari(苹果计算机的最新操作系统Mac OS X中的浏览器,使 ...

  10. Erlang 初学者技巧及避免的陷阱

    1. 传参或在匿名函数内慎用self() 通常在做消息传递或新建进程的时候我们需要将当前进程的Pid发给目标进程以便接收返回信息,但初学者不留意容易犯以下错误 spawn(fun() -> lo ...