为了账号安全,请及时绑定邮箱和手机立即绑定

为啥将斜体变为粗体就不行?

http://img1.sycdn.imooc.com//57e77199000144d104800486.jpg

求诸位大神详解


正在回答

4 回答

replaceChild(newnode,oldnode)每次使用的时候,所有与之相关的属性内容被清空,也就是说你第一次替换之后,那个位置的id属性已经清空了,变成了<i>JavaScript</i>,你已经无法通过oldnode=document.getElementById("oldnode")获取节点了,所以每次替换着以后你要给替换上的节点添加id属性,具体如下面代码

--------------------------------------------------------------

<!DOCTYPE html>

<html>

<head>

<meta charset="UTF-8">

<title>childNodes</title>

</head>

<body>

<script type="text/javascript">

function replaceMessage(){

var change=document.getElementById("change");

var oldnode=document.getElementById("oldnode");

if (oldnode.nodeName=="B"){

var newnode=document.createElement("i");

newnode.innerHTML=oldnode.innerHTML;

oldnode.parentNode.replaceChild(newnode,oldnode);

oldnode=null;

newnode.setAttribute("id","oldnode");

change.innerHTML="斜体改粗体";

}

else {

var newnode=document.createElement("b");

newnode.innerHTML=oldnode.innerHTML;

oldnode.parentNode.replaceChild(newnode,oldnode);

oldnode=null;

newnode.setAttribute("id","oldnode");

change.innerHTML="粗体改斜体";

}

}

</script>

<b id="oldnode">Java</b><br>

<a href="javascript:replaceMessage()" id="change">粗体改斜体</a>

</body>

</html>


1 回复 有任何疑惑可以回复我~
#1

qq_愁怅_03698152 提问者

非常感谢!
2016-10-06 回复 有任何疑惑可以回复我~

http://img1.sycdn.imooc.com//57e8b2a800013a9404690502.jpg

改成这样还是不行 该咋办了?


0 回复 有任何疑惑可以回复我~

没有将新创建的元素重新设置ID,应该在createElemrnt之后给新标签添加id:newnode.setAttribute("id", "oldnode");

1 回复 有任何疑惑可以回复我~
#1

qq_愁怅_03698152 提问者

怎么添加,我不会可以说的再详细点吗? 拜托了
2016-09-26 回复 有任何疑惑可以回复我~

大小写B有问题吧

1 回复 有任何疑惑可以回复我~
#1

qq_愁怅_03698152 提问者

我试过小写的 但是不行 直接 粗变斜都不行 不过 也谢谢你了
2016-09-26 回复 有任何疑惑可以回复我~

举报

0/150
提交
取消
JavaScript进阶篇
  • 参与学习       468043    人
  • 解答问题       21891    个

本课程从如何插入JS代码开始,带您进入网页动态交互世界

进入课程

为啥将斜体变为粗体就不行?

我要回答 关注问题
意见反馈 帮助中心 APP下载
官方微信