在Javascript字符串中奇怪地使用反斜杠

时间:2013-01-31 15:05:43

标签: javascript jquery multiline

我的一位同事在JS对象中设置属性的字符串值时使用了反斜杠:

shareButtonsHtml : '\
    <span class="share-fb">\
        <a href="#" class="fb-share"><span class="fb-share-icon"></span>Share</a>\
        <span class="fb-share-count"><i></i><u></u>0</span>\
    </span>\
    <div class="share-twitter"> \
        <iframe class="share-twitter-iframe" \
                allowtransparency="true" frameborder="0" scrolling="no" \
                src="https://platform.twitter.com/widgets/tweet_button.html" \
                style="width:130px; height:20px;"></iframe> \
    </div> \
    <div class="share-google"> \
        <div class="g-plusone" data-size="small" data-annotation="none"></div> \
    </div>',

我们对此字符串执行的唯一操作是在用户鼠标悬停时填充社交共享按钮容器:

self.html(obj.shareButtonsHtml);

我知道反斜杠是JS中的转义字符。谁能解释为什么我的同事在这里使用它们?当然他不需要逃离回车或换线?他后来转到另一家公司,所以我不能问他!

3 个答案:

答案 0 :(得分:5)

他正在逃避换行符。

如果您需要多行字符串,则需要这样做,否则JS不会将下一行识别为字符串的一部分。

所以,是的,他确实“需要逃避回车或换行”。这正是他在那里所做的。

您可以使用字符串连接在多行上传播字符串,但这意味着每次使用字符串时都需要额外的操作。性能差异不是很显着,主要是偏好问题。

多行蜇在JS中通常不起作用的原因是因为解释器(在大多数情况下*)在代码行的末尾添加了;,如果它已经存在的话。这就是;是可选的原因,但它也会打破多行字符串。

* 异常是对象/数组文字,;不会在那里添加,例如:

var obj = {
    a:1
}

答案 1 :(得分:4)

反斜杠用于在此处转义换行符。例如,它也可以在命令行中使用。

David Walsh撰写了一篇关于多行javascript字符串的精彩帖子: http://davidwalsh.name/multiline-javascript-strings

看起来你的同事实际上正在使用'慢和丑'方法之上的首选方法,使用加号(+)来连接字符串。

来自博客:

  

在每行的末尾添加反斜杠告诉JavaScript引擎该字符串将继续到下一行,从而避免自动分号插入烦恼。

答案 2 :(得分:1)

这只是允许他在多行上定义字符串(\正在转义“新行”字符)。