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

您所在的位置:网站首页 怎么让头条不自动刷新 实现a元素href URL链接自动刷新或新窗口打开 « 张鑫旭

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

2024-07-11 13:26| 来源: 网络整理| 查看: 265

by zhangxinxu from https://www.zhangxinxu.com/wordpress/?p=8994 本文欢迎分享与聚合,全文转载就不必了,尊重版权,圈子就这么大,若急用可以联系授权。

一、需求描述

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

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

关键是如何实现呢?

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

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

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

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

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

但是实际上,target还有一个隐藏特性,那就是可以指定为具体的URL地址或者任意自定义的名称。

例如:

空白页

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

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

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

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

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

空白页?s=1 空白页?s=2 三、结束语

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

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

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

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

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

感谢支持!

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

(本篇完)

相关文章HTML rel属性值释义大全 (0.303)URL锚点HTML定位技术机制、应用与问题 (0.222)如何实现页面刷新后不定位到之前的滚动位置? (0.222)如何使用JS把相对地址变成绝对地址? (0.203)一言难尽的registerProtocolHandler()方法 (0.148)jQuery-马化腾产品设计与用户体验的一些技术实现 (0.055)翻译 - 逐渐消失的Flash网站 (0.055)翻译:慢点更好-为何排序比速度更重要? (0.055)小tips: 滚动容器尺寸变化子元素视觉上位置不变JS实现 (0.055)5分钟快速了解下CSS4 color-adjust属性 (0.055)checkValidity等form原生JS验证方法和属性详细介绍 (RANDOM - 0.026)


【本文地址】


今日新闻


推荐新闻


CopyRight 2018-2019 办公设备维修网 版权所有 豫ICP备15022753号-3