这样的html结构,如何使用 js 动态修改文本,并且不影响子节点?


html如下:


 html


 <p>自定义文本<button>子节点</button></p>

我想根据 js 拿到的数据动态修改“自定义文本”处的文字,但是不影响 button 子节点(button 上面绑定了事件回调)。请问用什么方法可以做到呢?

前端 HTML JavaScript

lzqyydy 9 years, 8 months ago

拿到p里面的文字,再拿到button里面的文字,用p里面的文字减去button里面的文字就可以了

qiuzero answered 9 years, 8 months ago


小俞的方法最好:

在p标签的内部前面加上 字符
在button标签的外部加上
字符

然后在p标签中取span标签即可

yz10531 answered 9 years, 8 months ago

@小俞的方法最好

坑爹么这是 answered 9 years, 8 months ago

是不是可以先获取到button的outerHtml,然后在修改p里面的html,最后再把button append进去?这样会影响事件绑定吗

Blazers answered 9 years, 8 months ago


 <p><span>自定义文本</span><button>子节点</button></p>

†堕黑猫† answered 9 years, 8 months ago


 

<p id="test">自定义文本<button id="c">子节点</button></p> <script> var p = document.getElementById('test'), c = document.getElementById('c'); c.onclick = function(){ alert('事件还在!!'); }; setInterval(function(){ p.firstChild.nodeValue = Math.random(); }, 1000); </script>
其实我是椰子 answered 9 years, 8 months ago

Your Answer