JS里并没有标准的多行字符串的表示方法,但是在用模板的时候,为了保证模板的可阅读性,我们又不可避免的使用多行字符串,所以出现了各种搞法,这里以一段jade的模板作为示例,简单总结和对比一下。

一、字符串相加

这是最容易理解也很常用的一种形式,如下

  1. var tmpl =''+
  2. '!!! 5' +
  3. 'html' +
  4. ' include header' +
  5. ' body' +
  6. ' //if IE 6' +
  7. ' .alert.alert-error' +
  8. ' center 对不起,我们不支持IE6,请升级你的浏览器' +
  9. ' a(href="http://windows.microsoft.com/zh-CN/internet-explorer/download-ie") | IE8官方下载' +
  10. ' a(href="https://www.google.com/intl/en/chrome/browser/") | Chrome下载' +
  11. ' include head' +
  12. ' .container' +
  13. ' .row-fluid' +
  14. ' .span8' +
  15. ' block main' +
  16. ' include pagerbar' +
  17. ' .span4' +
  18. ' include sidebar' +
  19. ' include footer' +
  20. ' include script'

优点:

易理解,简单,可靠

足够灵活,可以在单个字符串中添加js逻辑

缺点 :

并不是真正意义上的多行字符串, 如果想要真正的多行,需要自己加\n

大量的+号看上去满天星,大量的'和", 丑陋

二、使用反斜线

这个叫续行符, 这个并非一种很常见的方式, 但是一旦用上了,还是很容易上瘾,只需要加一个字符

  1. var tmpl ='\
  2. !!! 5\
  3. html\
  4. include header\
  5. body\
  6. //if IE 6\
  7. .alert.alert-error\
  8. center 对不起,我们不支持IE6,请升级你的浏览器\
  9. a(href="http://windows.microsoft.com/zh-CN/internet-explorer/download-ie") | IE8官方下载\
  10. a(href="https://www.google.com/intl/en/chrome/browser/") | Chrome下载\
  11. include head\
  12. .container\
  13. .row-fluid\
  14. .span8\
  15. block main\
  16. include pagerbar\
  17. .span4\
  18. include sidebar\
  19. include footer\
  20. include script'

优点:

简单,每一行只需要有多一个\

高效!在大部分的浏览器上,这种方式都是最快的,

缺点 :

致命缺陷,每一行的\必须不可以有空格,否则直接脚本错误

并不是真正意义上的多行字符串, 如果想要真正的多行,需要自己加\n

尽管绝大部分的js引擎都支持它,但是它并不是ECMAScript的一部分

三、字符串数组join

  1. var tmpl = [
  2. '!!! 5' ,
  3. 'html' ,
  4. ' include header' ,
  5. ' body' ,
  6. ' //if IE 6' ,
  7. ' .alert.alert-error' ,
  8. ' center 对不起,我们不支持IE6,请升级你的浏览器' ,
  9. ' a(href="http://windows.microsoft.com/zh-CN/internet-explorer/download-ie") | IE8官方下载' ,
  10. ' a(href="https://www.google.com/intl/en/chrome/browser/") | Chrome下载' ,
  11. ' include head' ,
  12. ' .container' ,
  13. ' .row-fluid' ,
  14. ' .span8' ,
  15. ' block main' ,
  16. ' include pagerbar' ,
  17. ' .span4' ,
  18. ' include sidebar' ,
  19. ' include footer' ,
  20. ' include script'].join('\n');

优点:

真正意义上的多行字符串

易理解,简单,可靠

足够灵活,可以在单个字符串中添加js逻辑

缺点 :

大量的,号和'、", 丑陋

五、String.prototype.concat

  1. var tmpl = String.prototype.concat.call(
  2. '!!! 5' ,
  3. 'html' ,
  4. ' include header' ,
  5. ' body' ,
  6. ' //if IE 6' ,
  7. ' .alert.alert-error' ,
  8. ' center 对不起,我们不支持IE6,请升级你的浏览器' ,
  9. ' a(href="http://windows.microsoft.com/zh-CN/internet-explorer/download-ie") | IE8官方下载' ,
  10. ' a(href="https://www.google.com/intl/en/chrome/browser/") | Chrome下载' ,
  11. ' include head' ,
  12. ' .container' ,
  13. ' .row-fluid' ,
  14. ' .span8' ,
  15. ' block main' ,
  16. ' include pagerbar' ,
  17. ' .span4' ,
  18. ' include sidebar' ,
  19. ' include footer' ,
  20. ' include script');

优点:

不常用,事实上字符串的concat方法远没有+号常见

易理解,简单,可靠

足够灵活,可以在单个字符串中添加js逻辑

缺点 :

并不是真正意义上的多行字符串

大量的,号和'、", 丑陋

五、heredoc

这是一种很有技巧的解决办法, 利用了function的toString方法

  1. function heredoc(fn) {
  2. return fn.toString().split('\n').slice(1,-1).join('\n') + '\n'
  3. }
  4. var tmpl = heredoc(function(){/*
  5. !!! 5
  6. html
  7. include header
  8. body
  9. //if IE 6
  10. .alert.alert-error
  11. center 对不起,我们不支持IE6,请升级你的浏览器
  12. a(href="http://windows.microsoft.com/zh-CN/internet-explorer/download-ie") | IE8官方下载
  13. a(href="https://www.google.com/intl/en/chrome/browser/") | Chrome下载
  14. include head
  15. .container
  16. .row-fluid
  17. .span8
  18. block main
  19. include pagerbar
  20. .span4
  21. include sidebar
  22. include footer
  23. include script
  24. */});

优点:

模板字符串内不必写多余的任何字符,干净,简单

真正意义上的多行字符串, 有\n哦

缺点 :

不可以在单个字符串中添加js逻辑

容易被压缩器压缩掉,yui compressor可以通过/*!来避免被压缩掉,uglifyjs和gcc也可以通过选项配置不删除特定的注释,这个不是大问题

六、coffeescript

相当于换了一个语言,其实这种语言上缺少的功能,通过coffeescript这种以js为编译目标的语言来实现是一种非常棒的选择。

  1. var tmpl = """
  2. !!! 5
  3. html
  4. include header
  5. body
  6. //if IE 6
  7. .alert.alert-error
  8. center 对不起,我们不支持IE6,请升级你的浏览器
  9. a(href="http://windows.microsoft.com/zh-CN/internet-explorer/download-ie") | IE8官方下载
  10. a(href="https://www.google.com/intl/en/chrome/browser/") | Chrome下载
  11. include head
  12. .container
  13. .row-fluid
  14. .span8
  15. block main
  16. include pagerbar
  17. .span4
  18. include sidebar
  19. include footer
  20. include script
  21. """

优点:

易理解,简单,可靠

缺点 :

需要了解coffeescript

整个文件都需要用coffeescript来写

七、ES6

ES6的有一个新的特性,Template Strings, 这是语言层面上第一次实现了多行字符串, 在chrome canary里打开Enable Experimental JavaScript就可以使用这个特性,另外typescript也会支持这种方式

  1. var tmpl =
  2. `!!! 5
  3. html
  4. include header
  5. body
  6. //if IE 6
  7. .alert.alert-error
  8. center 对不起,我们不支持IE6,请升级你的浏览器
  9. a(href="http://windows.microsoft.com/zh-CN/internet-explorer/download-ie") | IE8官方下载
  10. a(href="https://www.google.com/intl/en/chrome/browser/") | Chrome下载
  11. include head
  12. .container
  13. .row-fluid
  14. .span8
  15. block main
  16. include pagerbar
  17. .span4
  18. include sidebar
  19. include footer
  20. include script`

优点:

易理解,原生支持

真正的多行字符串

缺点 :

JS引擎支持有限

八、总结

看了这么些写法,如何选择?如果你用的是coffeescript,放心大胆的使用它支持的多行字符串写法;如果是在客户端,同时你解决了你的压缩器去掉注释的问题,推荐使用heredoc;如果你无法解决压缩器的问题,使用反斜线连接吧,每行只需要加一个字符。

原文:http://www.jb51.net/article/49480.htm

javascript创建多行字符串的方法(转)的更多相关文章

  1. Javascript实现多行字符串

    打开百度首页,进入控制台的时候,我们在console控制台总可以看到一段文字: 这些文字是如何显示在控制台的呢?? Javascript中的函数被看作是一个对象拥有自己的方法,其中一个小方法fn.to ...

  2. javascript中数组和字符串的方法比较

    × 目录 [1]可索引 [2]转换 [3]拼接[4]创建[5]位置 前面的话 字符串和数组有很多的相同之处,它们的方法众多,且相似度很高:但它们又有不同之处,字符串是不可变值,于是可以把其看作只读的数 ...

  3. JavaScript基础知识(字符串的方法)

    字符串的方法 1.字符串: 在js中被单引号或双引号包起来的内容都是字符串: var t = "true"; console.log(typeof t);// "stri ...

  4. Javascript创建类的七种方法

    /* 第一种定义类的方法 */var cls = new Object();cls.name = "wyf";cls.showName = function(){console.l ...

  5. C++读入整行字符串的方法

    string s; getline(cin,s); cout<<s<<endl; ]; scanf("%[^\n]%*c",s); printf(" ...

  6. JavaScript创建和获取时间的方法

    一.获取时间常用方法 1.创建时间对象 var time=new Date() //创建当前的时间信息对象 var time1=new Date(2022,1,1,10,25,30) //创建2022 ...

  7. js 创建多行字符串

    function heredoc(fn) { ,-).join('\n') + '\n' } var tmpl = heredoc(function(){/* !!! 5 html include h ...

  8. PHP中的多行字符串传递给JavaScript方法两则

    PHP和JavaScript都是初学.近期有这么个需求: 例如说有一个PHP的多行字符串: $a = <<<EOF thy38 csdn blog EOF; 传递给JavaScrip ...

  9. JavaScript中字符串的方法:charAt()、charCodeAt()、indexOf()、lastIndexOf()、substr()、slice()、substring()、search()、replace()、split()、concat()、toLowerCase()、toUpperCase()

    1.字符创的创建: //1.通过new 来创建 var str = String("javascript"); //2.3.直接使用字面量进行创建 var str='html5'; ...

随机推荐

  1. 高性能 TCP & UDP 通信框架 HP-Socket v3.3.1

    HP-Socket 是一套通用的高性能 TCP/UDP 通信框架,包含服务端组件.客户端组件和 Agent 组件,广泛适用于各种不同应用场景的 TCP/UDP 通信系统,提供 C/C++.C#.Del ...

  2. jvm内存区域

    概述 jvm内存分为几个区域: 程序计数器 虚拟机栈 本地方法栈 堆 方法区 运行时常量池 直接内存 这些内存区域是在java进程中细分的,为java程序提供服务 不同的区域存储的内容不一样,生命周期 ...

  3. gitignore 规范

    gitignore 应该包含 5 块内容: 当前项目需要忽略的文件 项目性质需要忽略的文件(比如是 nodejs 项目,有些文件就需要忽略) 所有项目都需要忽略的文件(比如日志.临时文件) 操作系统需 ...

  4. 日期关联取最近日期的SQL

    SQL怎么关联,如下图A表用日期加产品编号关联B表的时候,如果日期不存在,则取之前最近一个日期的值,比如A表2012-07-31 关联B表,B表没有对应日期的,就取2012-07-30的 A表     ...

  5. Android简单介绍SharedPreference,内部文件,sdcard数据存储

    SharedPreference 以xml的结构储存简单的数据,储存在data/data/程序包名/shared_prefs文件夹中 使用方式 创建对象的方式有三种 Context 的 getShar ...

  6. 当Eclipse报版本低时的处理方法

    http://blog.sina.com.cn/s/blog_6f0c85e10100v6pv.html 更新到API12的时候出过问题,这一次难免又会出现了,不过我的版本还真全啊,哇咔咔~   这里 ...

  7. iOS10 适配问题-Xcode8

    前段时间升级了Xcode8,整体来说对OC的影响不大,但是还是跳一个坑,消耗了不少时间.这里总结下遇到的适配问题. 1.权限问题 Xcode8 访问相机.相册等需要权限的地方崩溃 解决办法: 在使用私 ...

  8. 苹果 OS X 系统U盘重装-抹盘重装、系统盘制作

    鉴于前段时间系统出了点问题,然后直接将盘抹了,来个彻底干净的系统重装.这里敲下过程.(网络恢复太慢了,我整整一个晚上竟然没down下来,恼怒了,直接U盘装) First,系统盘制作: 1.首先需要有: ...

  9. 关于JS交互--调用h5页面,点击页面的按钮,分享到微信朋友圈,好友

    关于js交互,在iOS中自然就想到了调用代理方法 另外就是下面的,直接上代码了: 如果你的后台需要知道你的分享结果,那么,就在回调里面调用上传到服务器结果的请求即可

  10. SQL连接操作符介绍(循环嵌套, 哈希匹配和合并连接)

    今天我将介绍在SQLServer 中的三种连接操作符类型,分别是:循环嵌套.哈希匹配和合并连接.主要对这三种连接的不同.复杂度用范例的形式一一介绍. 本文中使用了示例数据库AdventureWorks ...