栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > Web开发 > JavaScript

字符show,ES6模板字符串与标签化模板

JavaScript 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

字符show,ES6模板字符串与标签化模板

ES6字符串骚包点
  1. 模板字符串

  2. 标签化模板

模板字符串带过,主要解释标签化模板。


模板字符串

这个大家应该都用过,或许这个名字你不熟悉吧,如下:

let str = `

    

`

功能就是可以自助换行,方便布局。

哦,对,还有更好用的插入变量(替换位),如下:

let title = '打我啊,笨蛋'
let str = `

    

`

没错,你可以有多个替换位,这里不做演示。

我们主要说一说标签化模板。


标签化模板

上伪代码

let str = html`a${b}c` // Polymer里面一段代码形式

字符串模板好理解,可是前面那个html是什么鬼?当然,结合上下文还是可以猜出是个函数。

标签化模板:特殊的函数形式,参数为模板字符串根据替换位切割的各个部分,第一个参数是切割后的字符串数组,后续参数为各个替换位内容。

文本解释说不清楚,直接上代码分析:

function tag(param1, ...param2) {
    console.log(param1)
    console.log(param2)
    return '' // 返回结果
}

str = tag`a${`b`}c${`d`}` // ["a", "c", ""], ["b", "d"]

首先,模板字符串是可以嵌套模板字符串的,因为本身就是表达式。

然后,如上所述,第一个参数param1是一个数组,接的是切割后的内容,如果替换位在首位或末位,都会切除一个空字符,如例子中的["a", "c", ""]。

接着,param2应该是多个参数,不是数组,但是由于ES6提供了展开运算符,所以可以这样三点来处理,实际上可以写成如下这种,但是就没有了拓展性:

// 这种只能解决较为单一的业务
function tag(param1, param2, param3) {
    return '' // 返回结果
}

当然了,你也可以使用arguments来处理,但是还是老老实实用三个点的展开吧,多帅气不是?

最后,建议写法当然是展开运算符,里面使用遍历来获取所有参数,如下方式:

function tag(param1, ...param2) {
    let result = ''
    // param2一定比param1短一个,所以比较安全,不会越界
    for(let i = 0, j = param2.length; i < j; i++) {
 result += param1[i]
 result += param2[i]
    }
    result += param1.pop()

    return result
}

这个是模拟返回原数组的形式。

注意遍历的是param2,不是param1,否则一不小心就给越界了。


具体的用处可以参考Polymer写模板的方式,比如你传入的是html标签那种类似的模板字符串,那么某个解析函数就可以根据<>来将参数等匹配处理了。

ok,文章结束,有不懂或者需要讨论的,欢迎留言。


喜欢的话请务必关注一波,定期更新技术文章,满满的都是干货。

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/246702.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号