设置超链接在新的窗口中打开,而不是在本窗口中打开

      <a> 标签的 target 属性规定在何处打开链接文档。

      如果在一个 <a> 标签内包含一个 target 属性,浏览器将会载入和显示用这个标签的 href 属性命名的、名称与这个目标吻合的框架或者窗口中的文档。如果这个指定名称或 id 的框架或者窗口不存在,浏览器将打开一个新的窗口,给这个窗口一个指定的标记,然后将新的文档载入那个窗口。从此以后,超链接文档就可以指向这个新的窗口。

      设置超链接在新的窗口中打开的方法如下:

<a href="http://blog.csdn.net/xjun0812?viewmode=list" target="_blank">文章列表(新窗口打开)</a>
点击测试(新窗口打开)

点击测试(本窗口打开)

      其他设置:

      _self:默认。在相同的框架中打开被链接文档

      _parent:在父框架集中打开被链接文档。

      _top:在整个窗口中打开被链接文档

      当然也可以是自己定义的一个frame 的名字,比如

      <a href=" http://blog.csdn.net/xjun0812?viewmode=list"target="frame1">文章列表</a>

      扩展

      问题在 a 标签中已加入 target="_blank",而网页打开只在一个新窗口中打开,始终都在改新窗口中刷新内容,用户如果失去该窗口的焦点,在原窗口中点击 a 标签用户 看不到 新打开的窗体,实际已在失去焦点的窗体中刷新了内容,会给用户造成错觉,这就是为什么现在大家浏览有些网站会发现这个问题。

      解决方案一

      1、在 head 标签 加入<basetarget="_blank" />

      <head><basetarget="_blank" /></head>

      这样就能每次点击 打开新窗口。

      解决方案二、

      2、新建一个JS脚本文件external.js,并在里面输入如下代码:

function externallinks() {
    if (!document.getElementsByTagName) return;
    var anchors = document.getElementsByTagName("a");
    for (var i = 0; i < anchors.length; i++) {
        var anchor = anchors[i];
        if (anchor.getAttribute("href") &&
            anchor.getAttribute("rel") == "external")
            anchor.target = "_blank";
    }
}
window.onload = externallinks;
      html中写成:

<a href="http://www.baidu.com" rel="external">

      在点击a 标签就可以实现每次都在新窗体中打开。

      最后,时间仓促,资质有限,文中表述仅代表个人观点,部分内容参考自网络,不准确的地方还望见谅,欢迎严厉地指正。

可以使用CSS的伪类选择器`:hover`和属性选择器`[attribute=value]`来实现超链接新窗口打开的效果,具体方法如下: ```css a[target="_blank"]:hover { cursor: pointer; } a[target="_blank"]::after { content: "\2197"; /* 这是一个箭头符号,可以根据需要修改 */ margin-left: 5px; } a[target="_blank"]::after:hover { color: red; /* 可以根据需要修改箭头颜色 */ } /* 如果需要同时设置外部链接和内部链接在新窗口打开,可以使用如下代码 */ a[target="_blank"], a[href^="http"]:not([href*="example.com"]):not([href*="example.net"]) { /* 上面的选择器表示只针对带有target="_blank"属性的链接和不包含"example.com"或"example.net"域名的http链接生效 */ cursor: pointer; } a[target="_blank"]::after, a[href^="http"]:not([href*="example.com"]):not([href*="example.net"])::after { content: "\2197"; margin-left: 5px; } a[target="_blank"]::after:hover, a[href^="http"]:not([href*="example.com"]):not([href*="example.net"])::after:hover { color: red; } ``` 上述代码,选择器`a[target="_blank"]`表示选择带有`target="_blank"`属性的超链接,`a[target="_blank"]:hover`表示当鼠标悬停在这些链接上时的效果,`a[target="_blank"]::after`和`a[target="_blank"]::after:hover`表示在链接后面添加一个箭头符号和鼠标悬停时的效果。 如果需要同时设置内部链接和外部链接在新窗口打开,可以使用属性选择器`[href^="http"]`选择所有以"http"开头的链接,并使用`:not()`排除某些特定域名的链接。同时,由于使用`:hover`伪类选择器只能选已存在的元素,因此需要使用`::after`伪元素添加箭头符号。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值