javascript单引号和双引号区别

在一个网页中的按钮,写onclick事件的处理代码,不小心写成如下:
<input value="Test" type="button" οnclick="alert(""OK"");" />
IE提示出错后,再漫不经心地改为:
<input value="Test" type="button" οnclick="alert(\"OK\");" />
结果还是出错。
这时,我就想不通了,虽然我知道最直接的解决方法是写成这样:
<input value="" type="button" οnclick="alert('OK');" />
但为什么javascript中的转义字符\没有效果了呢?

后来找到一段正常的代码:
<input value="Test" type="button" οnclick="alert(&quot;OK&quot;);" />
这时才理解,原来这时,还是归于HTML的管辖范围,所以转义字符应该使用HTML的,而不是javascript的。两个双引号的做法是 vbScript的,\"这种做法则是javascript的,而HTML的,则是用&quot;,此外还可以使用:"、&#x27。

下面列出各种表达方法:
<html>
<body>
<input value="外双引号内双引号-错误" type="button" οnclick="alert("OK");" /><br />
<input value="外单引号内单引号-错误" type="button" οnclick='alert('OK');' /><br />
<input value="两个双引号-错误" type="button" οnclick="alert(""OK"");" /><br />
<input value="两个单引号-错误" type="button" οnclick="alert(''OK'');" /><br />
<input value="\+双引号-错误" type="button" οnclick="alert(\"OK\");" /><br />
<input value="\+单引号-错误" type="button" οnclick="alert(\'OK\');" /><br />
<input value="外双引号内单引号-OK" type="button" οnclick="alert('OK');" /><br />
<input value="外单引号内双引号-OK" type="button" οnclick='alert("OK");' /><br />
<input value="外部不使用引号-OK" type="button" οnclick=alert('OK');alert("OK"); /><br />
<input value="HTML转义字符"(& # 3 4 ;)-OK" type="button" οnclick="alert("OK");" /><br />
<input value="HTML转义字符'(& # 3 9 ;)-OK" type="button" οnclick="alert('OK');" /><br />
<input value="HTML转义字符"(& # x 2 2 ;)-OK" type="button" οnclick="alert('OK');" /><br />
<input value="HTML转义字符'(& # x 2 7 ;)-OK" type="button" οnclick="alert('OK');" /><br />
<input value="HTML转义字符&quot;(& q u o t ;)-OK" type="button" οnclick="alert(&quot;OK&quot;);" /><br />
<input value="HTML转义字符&apos;(& a p o s ;)-IE错误" type="button" οnclick="alert(&apos;OK&apos;);" /><br />

<input value="其它\\-错误" type="button" οnclick="alert(\\"OK\\");" /><br />
<input value="其它\& # 3 4 ;-错误" type="button" οnclick="alert(\"OK\");" /><br />
</body>
</html>


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 在 JavaScript 单引号双引号没有本质的区别,可以随意使用。不过,为了代码可读性和一致性,通常都使用单引号双引号作为字符串的引号。如果字符串已经包含了一种类型的引号,则可以使用另一种类型的引号来定义字符串,以避免转义。例如: ``` var string1 = 'This is a string.'; var string2 = "This is also a string."; var string3 = "This string contains a 'single quote' character."; var string4 = 'This string contains a "double quote" character.'; ``` ### 回答2: 在JavaScript单引号双引号都可用于表示字符串。它们之间的主要区别单引号双引号在语法上没有任何区别,但可以用于不同的情景和约定。 首先,使用单引号双引号不会影响字符串的功能,只是为了方便开发人员对代码进行书写和阅读。 其次,当字符串本身包含引号时,可以使用另一种引号来定义字符串,以避免冲突并简化代码书写。例如: let str1 = "This is a 'string'."; let str2 = 'This is a "string".'; 在上述例子,使用不同的引号来定义字符串,使得字符串的引号与定义字符串的引号分开,使代码更加简洁和易读。 此外,还存在一些约定俗成的规范,例如在HTML,属性值通常使用双引号,而JavaScript的字符串通常使用单引号。这只是一种约定,没有强制要求,但在开发共享代码或团队合作时,遵循这些约定可以提高代码的一致性和可读性。 总之,单引号双引号JavaScript的使用没有功能上的区别,只是为了方便和约定的不同。根据需要和个人偏好选择使用哪种引号来定义字符串。 ### 回答3: 在JavaScript单引号(')和双引号(")都可以用来声明字符串。它们之间的不同主要体现在两个方面:引号的嵌套和转义字符的使用。 首先,在字符串可以使用单引号包围双引号,或者使用双引号包围单引号,这样就可以避免引号的嵌套问题。例如,使用单引号声明的字符串可以包含双引号,反之亦然。这样一来,在编写包含引号的字符串时就更加灵活方便。 其次,转义字符在单引号双引号的使用略有不同。在双引号字符串,如果需要在字符串使用双引号本身,可以通过转义字符(\)来实现。例如,'"Hello, world!"'双引号需要通过转义字符进行转义。而在单引号字符串,则可以直接使用双引号,无需转义。同样地,在单引号字符串使用单引号时,无需转义字符,而在双引号字符串则需要转义。 总结起来,单引号双引号JavaScript用来声明字符串时,在引号的嵌套和转义字符的使用上有所不同。两者都可以用来声明字符串,但在特定的情况下可能更适合使用一种引号。选择哪种引号主要取决于个人的编码风格和需求。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值