javascript创建多行字符串的方法(转)
JS里并没有标准的多行字符串的表示方法,但是在用模板的时候,为了保证模板的可阅读性,我们又不可避免的使用多行字符串,所以出现了各种搞法,这里以一段jade的模板作为示例,简单总结和对比一下。
一、字符串相加
这是最容易理解也很常用的一种形式,如下
- var tmpl =''+
- '!!! 5' +
- 'html' +
- ' include header' +
- ' body' +
- ' //if IE 6' +
- ' .alert.alert-error' +
- ' center 对不起,我们不支持IE6,请升级你的浏览器' +
- ' a(href="http://windows.microsoft.com/zh-CN/internet-explorer/download-ie") | IE8官方下载' +
- ' a(href="https://www.google.com/intl/en/chrome/browser/") | Chrome下载' +
- ' include head' +
- ' .container' +
- ' .row-fluid' +
- ' .span8' +
- ' block main' +
- ' include pagerbar' +
- ' .span4' +
- ' include sidebar' +
- ' include footer' +
- ' include script'
优点:
易理解,简单,可靠
足够灵活,可以在单个字符串中添加js逻辑
缺点 :
并不是真正意义上的多行字符串, 如果想要真正的多行,需要自己加\n
大量的+号看上去满天星,大量的'和", 丑陋
二、使用反斜线
这个叫续行符, 这个并非一种很常见的方式, 但是一旦用上了,还是很容易上瘾,只需要加一个字符
- var tmpl ='\
- !!! 5\
- html\
- include header\
- body\
- //if IE 6\
- .alert.alert-error\
- center 对不起,我们不支持IE6,请升级你的浏览器\
- a(href="http://windows.microsoft.com/zh-CN/internet-explorer/download-ie") | IE8官方下载\
- a(href="https://www.google.com/intl/en/chrome/browser/") | Chrome下载\
- include head\
- .container\
- .row-fluid\
- .span8\
- block main\
- include pagerbar\
- .span4\
- include sidebar\
- include footer\
- include script'
优点:
简单,每一行只需要有多一个\
高效!在大部分的浏览器上,这种方式都是最快的,
缺点 :
致命缺陷,每一行的\必须不可以有空格,否则直接脚本错误
并不是真正意义上的多行字符串, 如果想要真正的多行,需要自己加\n
尽管绝大部分的js引擎都支持它,但是它并不是ECMAScript的一部分
三、字符串数组join
- var tmpl = [
- '!!! 5' ,
- 'html' ,
- ' include header' ,
- ' body' ,
- ' //if IE 6' ,
- ' .alert.alert-error' ,
- ' center 对不起,我们不支持IE6,请升级你的浏览器' ,
- ' a(href="http://windows.microsoft.com/zh-CN/internet-explorer/download-ie") | IE8官方下载' ,
- ' a(href="https://www.google.com/intl/en/chrome/browser/") | Chrome下载' ,
- ' include head' ,
- ' .container' ,
- ' .row-fluid' ,
- ' .span8' ,
- ' block main' ,
- ' include pagerbar' ,
- ' .span4' ,
- ' include sidebar' ,
- ' include footer' ,
- ' include script'].join('\n');
优点:
真正意义上的多行字符串
易理解,简单,可靠
足够灵活,可以在单个字符串中添加js逻辑
缺点 :
大量的,号和'、", 丑陋
五、String.prototype.concat
- var tmpl = String.prototype.concat.call(
- '!!! 5' ,
- 'html' ,
- ' include header' ,
- ' body' ,
- ' //if IE 6' ,
- ' .alert.alert-error' ,
- ' center 对不起,我们不支持IE6,请升级你的浏览器' ,
- ' a(href="http://windows.microsoft.com/zh-CN/internet-explorer/download-ie") | IE8官方下载' ,
- ' a(href="https://www.google.com/intl/en/chrome/browser/") | Chrome下载' ,
- ' include head' ,
- ' .container' ,
- ' .row-fluid' ,
- ' .span8' ,
- ' block main' ,
- ' include pagerbar' ,
- ' .span4' ,
- ' include sidebar' ,
- ' include footer' ,
- ' include script');
优点:
不常用,事实上字符串的concat方法远没有+号常见
易理解,简单,可靠
足够灵活,可以在单个字符串中添加js逻辑
缺点 :
并不是真正意义上的多行字符串
大量的,号和'、", 丑陋
五、heredoc
这是一种很有技巧的解决办法, 利用了function的toString方法
- function heredoc(fn) {
- return fn.toString().split('\n').slice(1,-1).join('\n') + '\n'
- }
- var tmpl = heredoc(function(){/*
- !!! 5
- html
- include header
- body
- //if IE 6
- .alert.alert-error
- center 对不起,我们不支持IE6,请升级你的浏览器
- a(href="http://windows.microsoft.com/zh-CN/internet-explorer/download-ie") | IE8官方下载
- a(href="https://www.google.com/intl/en/chrome/browser/") | Chrome下载
- include head
- .container
- .row-fluid
- .span8
- block main
- include pagerbar
- .span4
- include sidebar
- include footer
- include script
- */});
优点:
模板字符串内不必写多余的任何字符,干净,简单
真正意义上的多行字符串, 有\n哦
缺点 :
不可以在单个字符串中添加js逻辑
容易被压缩器压缩掉,yui compressor可以通过/*!来避免被压缩掉,uglifyjs和gcc也可以通过选项配置不删除特定的注释,这个不是大问题
六、coffeescript
相当于换了一个语言,其实这种语言上缺少的功能,通过coffeescript这种以js为编译目标的语言来实现是一种非常棒的选择。
- var tmpl = """
- !!! 5
- html
- include header
- body
- //if IE 6
- .alert.alert-error
- center 对不起,我们不支持IE6,请升级你的浏览器
- a(href="http://windows.microsoft.com/zh-CN/internet-explorer/download-ie") | IE8官方下载
- a(href="https://www.google.com/intl/en/chrome/browser/") | Chrome下载
- include head
- .container
- .row-fluid
- .span8
- block main
- include pagerbar
- .span4
- include sidebar
- include footer
- include script
- """
优点:
易理解,简单,可靠
缺点 :
需要了解coffeescript
整个文件都需要用coffeescript来写
七、ES6
ES6的有一个新的特性,Template Strings, 这是语言层面上第一次实现了多行字符串, 在chrome canary里打开Enable Experimental JavaScript就可以使用这个特性,另外typescript也会支持这种方式
- var tmpl =
- `!!! 5
- html
- include header
- body
- //if IE 6
- .alert.alert-error
- center 对不起,我们不支持IE6,请升级你的浏览器
- a(href="http://windows.microsoft.com/zh-CN/internet-explorer/download-ie") | IE8官方下载
- a(href="https://www.google.com/intl/en/chrome/browser/") | Chrome下载
- include head
- .container
- .row-fluid
- .span8
- block main
- include pagerbar
- .span4
- include sidebar
- include footer
- include script`
优点:
易理解,原生支持
真正的多行字符串
缺点 :
JS引擎支持有限
八、总结
看了这么些写法,如何选择?如果你用的是coffeescript,放心大胆的使用它支持的多行字符串写法;如果是在客户端,同时你解决了你的压缩器去掉注释的问题,推荐使用heredoc;如果你无法解决压缩器的问题,使用反斜线连接吧,每行只需要加一个字符。
原文:http://www.jb51.net/article/49480.htm
javascript创建多行字符串的方法(转)的更多相关文章
- Javascript实现多行字符串
打开百度首页,进入控制台的时候,我们在console控制台总可以看到一段文字: 这些文字是如何显示在控制台的呢?? Javascript中的函数被看作是一个对象拥有自己的方法,其中一个小方法fn.to ...
- javascript中数组和字符串的方法比较
× 目录 [1]可索引 [2]转换 [3]拼接[4]创建[5]位置 前面的话 字符串和数组有很多的相同之处,它们的方法众多,且相似度很高:但它们又有不同之处,字符串是不可变值,于是可以把其看作只读的数 ...
- JavaScript基础知识(字符串的方法)
字符串的方法 1.字符串: 在js中被单引号或双引号包起来的内容都是字符串: var t = "true"; console.log(typeof t);// "stri ...
- Javascript创建类的七种方法
/* 第一种定义类的方法 */var cls = new Object();cls.name = "wyf";cls.showName = function(){console.l ...
- C++读入整行字符串的方法
string s; getline(cin,s); cout<<s<<endl; ]; scanf("%[^\n]%*c",s); printf(" ...
- JavaScript创建和获取时间的方法
一.获取时间常用方法 1.创建时间对象 var time=new Date() //创建当前的时间信息对象 var time1=new Date(2022,1,1,10,25,30) //创建2022 ...
- js 创建多行字符串
function heredoc(fn) { ,-).join('\n') + '\n' } var tmpl = heredoc(function(){/* !!! 5 html include h ...
- PHP中的多行字符串传递给JavaScript方法两则
PHP和JavaScript都是初学.近期有这么个需求: 例如说有一个PHP的多行字符串: $a = <<<EOF thy38 csdn blog EOF; 传递给JavaScrip ...
- 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'; ...
随机推荐
- 高性能 TCP & UDP 通信框架 HP-Socket v3.3.1
HP-Socket 是一套通用的高性能 TCP/UDP 通信框架,包含服务端组件.客户端组件和 Agent 组件,广泛适用于各种不同应用场景的 TCP/UDP 通信系统,提供 C/C++.C#.Del ...
- jvm内存区域
概述 jvm内存分为几个区域: 程序计数器 虚拟机栈 本地方法栈 堆 方法区 运行时常量池 直接内存 这些内存区域是在java进程中细分的,为java程序提供服务 不同的区域存储的内容不一样,生命周期 ...
- gitignore 规范
gitignore 应该包含 5 块内容: 当前项目需要忽略的文件 项目性质需要忽略的文件(比如是 nodejs 项目,有些文件就需要忽略) 所有项目都需要忽略的文件(比如日志.临时文件) 操作系统需 ...
- 日期关联取最近日期的SQL
SQL怎么关联,如下图A表用日期加产品编号关联B表的时候,如果日期不存在,则取之前最近一个日期的值,比如A表2012-07-31 关联B表,B表没有对应日期的,就取2012-07-30的 A表 ...
- Android简单介绍SharedPreference,内部文件,sdcard数据存储
SharedPreference 以xml的结构储存简单的数据,储存在data/data/程序包名/shared_prefs文件夹中 使用方式 创建对象的方式有三种 Context 的 getShar ...
- 当Eclipse报版本低时的处理方法
http://blog.sina.com.cn/s/blog_6f0c85e10100v6pv.html 更新到API12的时候出过问题,这一次难免又会出现了,不过我的版本还真全啊,哇咔咔~ 这里 ...
- iOS10 适配问题-Xcode8
前段时间升级了Xcode8,整体来说对OC的影响不大,但是还是跳一个坑,消耗了不少时间.这里总结下遇到的适配问题. 1.权限问题 Xcode8 访问相机.相册等需要权限的地方崩溃 解决办法: 在使用私 ...
- 苹果 OS X 系统U盘重装-抹盘重装、系统盘制作
鉴于前段时间系统出了点问题,然后直接将盘抹了,来个彻底干净的系统重装.这里敲下过程.(网络恢复太慢了,我整整一个晚上竟然没down下来,恼怒了,直接U盘装) First,系统盘制作: 1.首先需要有: ...
- 关于JS交互--调用h5页面,点击页面的按钮,分享到微信朋友圈,好友
关于js交互,在iOS中自然就想到了调用代理方法 另外就是下面的,直接上代码了: 如果你的后台需要知道你的分享结果,那么,就在回调里面调用上传到服务器结果的请求即可
- SQL连接操作符介绍(循环嵌套, 哈希匹配和合并连接)
今天我将介绍在SQLServer 中的三种连接操作符类型,分别是:循环嵌套.哈希匹配和合并连接.主要对这三种连接的不同.复杂度用范例的形式一一介绍. 本文中使用了示例数据库AdventureWorks ...