实现a元素href URL链接自动刷新或新窗口打开
一、需求描述
希望实现这样一个功能:点击一个链接,如果这个链接浏览器已经打开过,则刷新已经打开的链接窗口;如果这个链接没有打开过,则使用新窗口打开这个链接页面。
这是一个非常好的体验增强功能,可以有效避免浏览器选项卡中打开重复多余的页面。
关键是如何实现呢?
其实很简单,并不需要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
可以看到, target="blank.html?s=1" 和 target="blank.html?s=2" 会认为是两个独立的页面,不会互相刷新。因此,如果想要实现所有的搜索结果页都使用一个标签页选项卡,需要想想其他办法。
三、结束语
要想实现 <a> 元素 href 链接自动刷新或新窗口打开的功能,只需要设置 target 属性值和 href 属性值一样就好了。
这个特性IE浏览器,Firefox浏览器,以及Chrome浏览器都是支持的,放心使用。
原文来自:https://www.zhangxinxu.com/wordpress/?p=8994
本文内容仅供个人学习、研究或参考使用,不构成任何形式的决策建议、专业指导或法律依据。未经授权,禁止任何单位或个人以商业售卖、虚假宣传、侵权传播等非学习研究目的使用本文内容。如需分享或转载,请保留原文来源信息,不得篡改、删减内容或侵犯相关权益。感谢您的理解与支持!