[JavaScript]让网页的“外部超连结”自动开启在新视窗
在编辑网页时,如果要让某个超连结 (Link) 开启在新的浏览器视窗,我们可以在超连结加上“href="_blank"”属性,但如果超连结很多,要一个一个加上去毕竟麻烦!!
以下的程式码可以帮你把网页内所有针对“外部”的超连结自动设为在新视窗开启。
一般网页
- 将下列程式码加到网页的 <head> 区段:
<script type="text/javascript"> function parseLink(){ var tagA = document.getElementsByTagName( "a" ); re = new RegExp( "^(http://" + document.domain + ")|(javascript:)", "i" ); for( var i=0; i < tagA.length; i++ ){ if( !tagA[i].href.match( re ) ){ tagA[i].target = "_blank"; } } } </script>
- 在 <body> 标签内的 onload 事件加入:
parseLink();
Ex:
<body onload="parseLink();">
WordPress 外挂程式
如果你的网站是用 WordPress 架设,可直接在控制台搜寻并安装“Open external links in a new window”这个外挂程式 (版本: 1.3.1 作者: Kristian Risager Larsen),这样就不用添加任何程式码了。
另外需注意,如果本外挂程式与其它像 LightBox、FancyBox...之类的图片灯箱特效的程式一起使用,有可能会造成同时显示灯箱特效,又同时将图片开启于新视窗!!
用BASE就可以啦
http://www.w3schools.com/tags/tag_base.asp
Base Tag 是让 "所有的" 超连结都开启在新视窗,上面的程式是让 "本站以外" 的超连结自动开启在新视窗,站内的超连结还是开启在原视窗。
你好
请问一下
第二段的parseLink();
是要加在ONLOAD的哪边呢? 不好意思我试了很久不行才来询问的...
感谢
下面是我BLOG的程式码
--------------------------------------------------------------------------------------------
google.annotations.createAll();
google.annotations.fetch();
}
google.setOnLoadCallback(initialize);
---------------------------------------------------------------------------------------------
To 阿丹:
找找看样板里有没有 "<body>" 这标签,改成:
<body onload="parseLink()">
你好,我想请问一下,function的程式码中有需要修改的地方吗?
因为我照着修改还是会在原本的页面开启连结,还是说是因为我的网页是导入的页面,所以不可以用此方法呢?
我们无法剖析您的范本,因为它的结构不完整。 请确定所有的 XML 元素均已正确关闭。
XML 错误讯息: Element type "tagA.length" must be followed by either attribute specifications, ">" or "/>".
好像是判读小于的问题...奇怪...
找到解答了 用字符i<代替<
站长您好,我找这个功能很久了,请问在wordpress有方法进行同样的设定吗?谢谢!!
在 WordPress 可直接在控制台搜寻并安装 Open external links in a new window 这个外挂程式 (版本: 1.3.1 作者: Kristian Risager Larsen),就不用修改程式码了。
谢谢回答,已安装可以正常运行,谢谢^_____^
p.s. 我有勾选"用电子邮件通知我后续的回响",可是似乎没有收到回信...
请问,我要如何让“子网域”也视为“站外”
让它在新视窗开启呢?