Ruby's Louvre

每天学习一点点算法

导航

< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5

统计

获取元素的文本

记得John Resig说过,类库就是用来屏蔽浏览器的差异,但他的getText函数就明显做不到这一点,怎么没人去提醒他一下呢?我的英文特烂,阅读还可以,但要我正经八儿地写几句英文,估计句句都是病句……不说了,看下面测试(如果在IE下报错,请刷新当前页面):

IE下明显少了空行与空白,因为IE会自动删除空白节点。所以,要让所有浏览器保持一下,就只有去掉空白节点了。还有,我不明白jQuery会把所有匹配元素的文本串成一个,为何不返回一个字符串数组呢,省得到时我们还要一个个分解……

下面是我的方案:

//@author:司徒正美(zhongqincheng)
//获取某个节点的文本,如果此节点为元素节点,则取其childNodes的所有文本,
//为了让结果在所有浏览器下一致,忽略所有空白节点,因此它非元素的innerText或textContent
var getText = function(nodes){
  var result = "",node;
  for(var i=0,n=nodes.length;i<n;i++){
    node = nodes[i];
    //如果是文本节点或者CDATA节点
    if ( node.nodeType === 3 || node.nodeType === 4 ) {
      if(!/^\s+$/.test(node.nodeValue))//忽略空白节点与换行符
        result += node.nodeValue;
      //如果是元素节点
    } else if ( node.nodeType === 1 ) {
      result += getText( node.childNodes );
    }
  }
  return result;
}

看一下效果:

如果您觉得此文有帮助,可以打赏点钱给我支付宝1669866773@qq.com ,或扫描二维码

posted on   司徒正美  阅读(2214)  评论(3编辑  收藏  举报

编辑推荐:
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
点击右上角即可分享
微信分享提示