手机
当前位置:查字典教程网 >编程开发 >Javascript教程 >用JavaScript实现用一个DIV来包装文本元素节点
用JavaScript实现用一个DIV来包装文本元素节点
摘要:当你的应用需要依赖某个特定的JavaScript类库时,你无意中总会试图解决某些类库自身的问题,而不是语言的问题。就比如当我试图将文本(可能...

当你的应用需要依赖某个特定的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实现用一个DIV来包装文本元素节点】相关文章:

纯javascript实现四方向文本无缝滚动效果

JavaScript动态添加style节点的方法

JavaScript实现表格点击排序的方法

JavaScript里实用的原生API汇总

javascript实现获取服务器时间

使用RequireJS优化JavaScript引用代码的方法

JavaScript实现弹出模态窗体并接受传值的方法

JavaScript实现添加、查找、删除元素

javascript实现查找数组中最大值方法汇总

Javascript实现图片轮播效果(二)图片序列节点的控制实现

精品推荐
分类导航