精通JavaScript 糾正 cleanWhitespace函數(shù)
更新時(shí)間:2010年03月11日 16:47:15 作者:
這個(gè)函數(shù)用在火狐(firefox)上面老是出錯(cuò),今天仔細(xì)研究了下,改正了,希望別人不要遇到我這樣的問題
復(fù)制代碼 代碼如下:
function cleanWhitespace(element){
//如果不提供參數(shù),則處理整個(gè)HTML文檔
element = element || document;
//使用第一個(gè)子節(jié)點(diǎn)作為開始指針
var cur = element.firstChild;
//臨時(shí)變量用來保存當(dāng)前節(jié)點(diǎn)的下個(gè)節(jié)點(diǎn)
var tmp;
//一直到?jīng)]有子節(jié)點(diǎn)為止
while (cur != null){
//保存當(dāng)前節(jié)點(diǎn)的下個(gè)節(jié)點(diǎn)
tmp=cur.nextSibling
//如果節(jié)點(diǎn)為文本節(jié)點(diǎn),應(yīng)且包含空格
if ( cur.nodeType == 3 && ! /\S/.test(cur.nodeValue)){
//刪除這個(gè)文本節(jié)點(diǎn)
element.removeChild( cur );
//否則,它就是一個(gè)元素
} else if (cur.nodeType == 1){
//遞歸整個(gè)文檔
cleanWhitespace( cur );
}
cur = tmp;//遍歷子節(jié)點(diǎn)
}
}
還轉(zhuǎn)一個(gè)可以用的
復(fù)制代碼 代碼如下:
function cleanWhitespace2(node) {
var notWhitespace = /\S/;
for (var i=0; i < node.childNodes.length; i++) {
var childNode = node.childNodes[i];
if ((childNode.nodeType == 3)&&(!notWhitespace.test(childNode.nodeValue))) {
node.removeChild(node.childNodes[i]);
i--;
}
if (childNode.nodeType == 1) {
cleanWhitespace2(childNode);
}
}
}
如果只清除本節(jié)點(diǎn)的空白,不遍歷子節(jié)點(diǎn)
復(fù)制代碼 代碼如下:
function cleanWhitespace2(oEelement)
{
for(var i=0;i<oEelement.childNodes.length;i++){
var node=oEelement.childNodes[i];
if(node.nodeType==3 && !/\S/.test(node.nodeValue)){node.parentNode.removeChild(node)}
}
}
還轉(zhuǎn)一個(gè)可以用的
復(fù)制代碼 代碼如下:
function cleanWhitespace2(node) {
var notWhitespace = /\S/;
for (var i=0; i < node.childNodes.length; i++) {
var childNode = node.childNodes[i];
if ((childNode.nodeType == 3)&&(!notWhitespace.test(childNode.nodeValue))) {
node.removeChild(node.childNodes[i]);
i--;
}
if (childNode.nodeType == 1) {
cleanWhitespace2(childNode);
}
}
}
如果只清除本節(jié)點(diǎn)的空白,不遍歷子節(jié)點(diǎn)
復(fù)制代碼 代碼如下:
function cleanWhitespace2(oEelement)
{
for(var i=0;i<oEelement.childNodes.length;i++){
var node=oEelement.childNodes[i];
if(node.nodeType==3 && !/\S/.test(node.nodeValue)){node.parentNode.removeChild(node)}
}
}
相關(guān)文章
Highcharts學(xué)習(xí)之坐標(biāo)軸
今天講交互圖表Highcharts的坐標(biāo)軸,我們將對(duì)Highcharts圖表的坐標(biāo)軸組成、坐標(biāo)軸類型等進(jìn)行詳細(xì)系統(tǒng)講解。下面一起來看看。2016-08-08精通JavaScript 糾正 cleanWhitespace函數(shù)
這個(gè)函數(shù)用在火狐(firefox)上面老是出錯(cuò),今天仔細(xì)研究了下,改正了,希望別人不要遇到我這樣的問題2010-03-03Three.js學(xué)習(xí)之文字形狀及自定義形狀
今天小編帶大家學(xué)習(xí)的是Three.js的文字形狀與自定義形狀,文章內(nèi)容很詳細(xì),對(duì)大家學(xué)習(xí)Three.js或許有幫助,下面一起來看看吧。2016-08-08