强制修改wordpress的正文链接为新开窗口打开
WordPress的正文做链接的时候,默认是本页打开的,用livewriter写博客的时候也是默认本页打开。当然据说这样更符合国际化标准,但是好像对中国人的习惯新开页面得习惯有点水土不服。而且外带我很懒的去给所有的链接去增加target=’_blank’属性。今天说的是,批量修改这些页面链接,强制新开页面。
一、写在前面
本文主要使用了一个函数,getElementsByClassName,这个是prototy.js中的一个标准函数,但是单独运行版却是多种多样,而且兼容性很差,本来想扩展object.prototype.getElementsByClassName,但是发现时好时坏,兼容性很差。后来就google到了这么一个函数,貌似很不错的说。
http://robertnyman.com/2005/11/07/the-ultimate-getelementsbyclassname/
http://code.google.com/p/getelementsbyclassname/
二、不多说,上代码
getElementsByClassName:
var getElementsByClassName = function (className, tag, elm){
if (document.getElementsByClassName) {
getElementsByClassName = function (className, tag, elm) {
elm = elm || document;
var elements = elm.getElementsByClassName(className),
nodeName = (tag)? new RegExp("\\b" + tag + "\\b", "i") : null,
returnElements = [],
current;
for(var i=0, il=elements.length; i<il; i+=1){
current = elements[i];
if(!nodeName || nodeName.test(current.nodeName)) {
returnElements.push(current);
}
}
return returnElements;
};
}
else if (document.evaluate) {
getElementsByClassName = function (className, tag, elm) {
tag = tag || "*";
elm = elm || document;
var classes = className.split(" "),
classesToCheck = "",
xhtmlNamespace = "http://www.w3.org/1999/xhtml",
namespaceResolver = (document.documentElement.namespaceURI === xhtmlNamespace)? xhtmlNamespace : null,
returnElements = [],
elements,
node;
for(var j=0, jl=classes.length; j<jl; j+=1){
classesToCheck += "[contains(concat(' ', @class, ' '), ' " + classes[j] + " ')]";
}
try {
elements = document.evaluate(".//" + tag + classesToCheck, elm, namespaceResolver, 0, null);
}
catch (e) {
elements = document.evaluate(".//" + tag + classesToCheck, elm, null, 0, null);
}
while ((node = elements.iterateNext())) {
returnElements.push(node);
}
return returnElements;
};
}
else {
getElementsByClassName = function (className, tag, elm) {
tag = tag || "*";
elm = elm || document;
var classes = className.split(" "),
classesToCheck = [],
elements = (tag === "*" && elm.all)? elm.all : elm.getElementsByTagName(tag),
current,
returnElements = [],
match;
for(var k=0, kl=classes.length; k<kl; k+=1){
classesToCheck.push(new RegExp("(^|\\s)" + classes[k] + "(\\s|$)"));
}
for(var l=0, ll=elements.length; l<ll; l+=1){
current = elements[l];
match = false;
for(var m=0, ml=classesToCheck.length; m<ml; m+=1){
match = classesToCheck[m].test(current.className);
if (!match) {
break;
}
}
if (match) {
returnElements.push(current);
}
}
return returnElements;
};
}
return getElementsByClassName(className, tag, elm);
};
一点针对WordPress的小补充:
var par=document.getElementById("main");
var content=getElementsByClassName("content","div",par)[0];
var tlinks=content.getElementsByTagName("a");
for (var i=0;i<tlinks.length;i++){
tlinks[i].target="_blank";
}
使用起来也很方便,放到当前主题的end.php的结尾就行了。hoho~
三、写在最后
当然,如果不是想修改正文内容的链接,而是所有的链接的的target的属性的话,就好说了,在head区加个<base target=‘_blank’>就行了,够简单的说。hoho~
本文来自苏南的博客, 转载请注明网址:http://newsn.net, 谢谢!
我的淘宝小店:http://68zz.com
我的Sina圈子:http://q.blog.sina.com.cn/pctalk

这种修改太无聊了~~~