使用Pure JS更改HTML标记名称

时间:2015-04-07 10:16:14

标签: javascript tagname

<div id="demo"></div>
document.getElementsById("demo").onclick = function() {
    this.tagName = "p";
};
// and then the output should be:
<p id="demo"></p>

我想使用纯JavaScript来更改标记名称,任何人都可以帮忙吗?

1 个答案:

答案 0 :(得分:0)

使用一些时髦的dom Manipulation,你可以轻松地做到这一点。

你只需要创建一个新元素,移动所有元素,这样就可以保持onclick处理程序等,然后替换原始元素。

function addClickEventToSpan() {
  document.getElementById('whoa').addEventListener("click",function(){alert('WHOA WORLD! HELLO!');});
}
function transform(id){
     var that = document.getElementById(id);
  
     var p = document.createElement('p');
     p.setAttribute('id',that.getAttribute('id'));
     
     // move all elements in the other container.
     // remember to use firstchild so you take all the childrens with you and maintain order.
     // unles you like reversed order things.
     while(that.firstChild) {
       p.appendChild(that.firstChild);
     }
     that.parentNode.replaceChild(p,that);
     
}
p { background-color:green;color:white; }
div { background-color:blue;color:white; }
<div id="demo">Hello fantastical<span id="whoa" style="color:red">WORLD</span>
       <UL>
          <LI>something</LI>
  </UL>
</div>

<input type="button" onclick="addClickEventToSpan('demo')" value="bind event handler(click WORLD)">
<input type="button" onclick="transform('demo')" value="transform">