html多重引号嵌套

    html中有多层引号嵌套,就会导致字符串被截取等问题

    引号嵌套两层时,可以使用转义或者单双引号交替的形式实现,当引号嵌套达到三四层的时候,问题就出现了。

    比如下面这段是嵌套三层时的正确写法(双引号嵌套单引号,单引号又嵌套转译单引号):

<html>
<head>
<script>
function execScript(code){
    var script = document.createElement("script");
     script.type = "text/javascript";
     try {
          /*适用于除IE浏览器以外的浏览器。不适用IE是因为IE把<script>当成特殊元素,不允许操作其子节点*/
         script.appendChild(document.createTextNode(code));
         } catch (ex){
              /*适用IE浏览器*/
             script.text = code;
        }
        document.body.appendChild(script);
}
</script>
</head>
<body>
  <input type="button" value="执行javascript代码" οnclick="execScript(alert('I \'m Chinese'))">
</body>

正确的做法有:

  • 上面的正确写法是双引号嵌套单引号,单引号又嵌套转译单引号;
  • 还有正确做法是单引号嵌套双引号,双引号又嵌套转译双引号。

错误的做法有:

  • 双引号嵌套单引号,单引号又嵌套转译双引号。解析时会在第一个转译双引号处中断。比如上面的例子按钮onclick事件改成οnclick="execScript(alert('I \"m Chinese'))",就会出现错误,会被截取为"execScript(alert('I \" ;
  • 单引号嵌套双引号,双引号又嵌套转译单引号。解析时会在第一个转译单引号处中断。

    三层适用转译一不小心就会出现错误,那如果有更多层更复杂的嵌套怎么解决呢?

    解决的方法是使用 &quot; 代替引号。比如上面的例子改成:οnclick="execScript(alert(&quot;I'm Chinese&quot;))"

  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值