码迷,mamicode.com
首页 > 编程语言 > 详细

用JavaScript来包装文本元素节点

时间:2014-09-06 12:26:43      阅读:267      评论:0      收藏:0      [点我收藏+]

标签:javascript   移动   dom   文本   包装   

原文日期: 2014-09-04
翻译日期: 2014-09-06
翻译人员: 铁锚

当你的应用需要依赖某个特定的JavaScript类库时,你无意中总会试图解决某些类库自身的问题,而不是语言的问题。就比如当我试图将文本(可能也包含HTML元素)用一个DIV元素包起来时。假设有以下HTML:
This is some text and <a href="">a link</a>.

这时候如果想把它转换为下面这样:
<div>This is some text and <a href="">a link</a>.<div>

最简单暴力的方法是,你可以在父元素上通过 .innerHTML 属性来执行更新,但问题是这样一来所有绑定的事件监听都会失效,因为使用 innerHTML  时会重新创建一个HTML元素。这真是个大玻璃杯!所以这时候只能利用JavaScript来实现 —— 尺有所短、寸有所长。下面是实现代码:
var newWrapper = document.createElement(‘div‘);
while(existingParent.firstChild) {
    // 移动DOM元素,不会创建新元素
    newWrapper.appendChild(existingParent.firstChild);
}

这里不能使用for循环,因为 childNodes 是一个动态节点组成的集合,只要移动节点就会影响到他的index索引值。我们用while循环一直检测父元素的 firstChild ,如果其返回一个代表 false 的值,  那么你就知道所有的节点都已经移到新的parent中了!

用JavaScript来包装文本元素节点

标签:javascript   移动   dom   文本   包装   

原文地址:http://blog.csdn.net/renfufei/article/details/39100075

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!