16

实现a元素href URL链接自动刷新或新窗口打开

 4 years ago
source link: https://www.tuicool.com/articles/RVJFNn6
Go to the source link to view the article. You can view the picture content, updated content and better typesetting reading experience. If the link is broken, please click the button below to view the snapshot at that time.

byzhangxinxu from https://www.zhangxinxu.com/wordpress/?p=8994

本文欢迎分享与聚合,全文转载就不必了,尊重版权,圈子就这么大,若急用可以联系授权。

QvqIF3y.jpg!web

一、需求描述

希望实现这样一个功能:点击一个链接,如果这个链接浏览器已经打开过,则刷新已经打开的链接窗口;如果这个链接没有打开过,则使用新窗口打开这个链接页面。

这是一个非常好的体验增强功能,可以有效避免浏览器选项卡中打开重复多余的页面。

关键是如何实现呢? QJ7jye7.png!web

其实很简单,并不需要JS的参与,HTML本身特性就可以实现这样的需求。

二、你可能不知道的target属性特性

无论是 <a> 链接元素还是 <form> 表单元素都有一个名叫 target 的属性,支持的值包括下面这些:

  • _self :默认值。当前浏览器上下文。
  • _blank :通常是一个新的标签页,但是用户可以配置浏览器,是否在新窗口打开。
  • _parent :当前浏览器上下文的的父级上下文,如果没有父级,则行为类似 _self
  • _top :最顶级的浏览器上下文。如果没有祖先上下文环境,则行为类似 _self .

几乎所有的文档都是上面这样的描述。

但是实际上, target 还有一个隐藏特性,那就是可以指定为具体的URL地址。

例如:

<a href="blank.html" >target="blank.html">空白页</a>

此时,如果浏览器已经有标签页的地址是blank.html,则点击上面的链接并不会打开新窗口,是直接刷新已经打开的blank.html;如果浏览器中没有地址是blank.html的标签页,则此时 target 属性的行为表现类似 '_blank'

也就是说,我们要想实现链接地址自动刷新和新窗口打开的这个需求,知道设置链接元素和表单元素的 target 属性值为目标URL地址值就好了。

您可以狠狠地点击这里: 链接新窗口打开或者刷新demo

点击任意这几个链接,可以体验效果。

AjeIjyQ.png!web

可以看到, target="blank.html?s=1"target="blank.html?s=2" 会认为是两个独立的页面,不会互相刷新。因此,如果想要实现所有的搜索结果页都使用一个标签页选项卡,需要想想其他办法。

三、结束语

要想实现 <a> 元素 href 链接自动刷新或新窗口打开的功能,只需要设置 target 属性值和 href 属性值一样就好了。

这个特性IE浏览器,Firefox浏览器,以及Chrome浏览器都是支持的,放心使用。

由于老备案凉了,目前网站架在香港主机上,所以访问速度可能略微有些慢,等老备案注销新备案成功,会恢复,可能要3周时间。

为了少点迁移麻烦,所以本月更新内容不会频繁。

最后,安利下,我的新书《CSS选择器世界》签名版 淘宝也可以购买 了。

bmyAvae.png!web

感谢支持!

fIFNBvU.png!web

本文为原创文章,欢迎分享,勿全文转载,如果内容你实在喜欢,可以加入收藏夹,永不过期,而且还会及时更新知识点以及修正错误,阅读体验也更好。

本文地址: https://www.zhangxinxu.com/wordpress/?p=8994

(本篇完)


About Joyk


Aggregate valuable and interesting links.
Joyk means Joy of geeK