亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定

字符show,ES6模板字符串與標簽化模板

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

  2. 标签化模板

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


模板字符串

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

let str = `
<div>
    <button>打我啊,笨蛋</button>
</div>
`

/** "
 * <div>
 *     <button>打我啊,笨蛋</button>
 * </div>
 * "
 */

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

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

let title = '打我啊,笨蛋'
let str = `
<div>
    <button>${title}</button>
</div>
`
/** "
 * <div>
 *     <button>打我啊,笨蛋</button>
 * </div>
 * "
 */

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

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


标签化模板

上伪代码

let str = html`a$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,文章结束,有不懂或者需要讨论的,欢迎留言。


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

點擊查看更多內容
1人點贊

若覺得本文不錯,就分享一下吧!

評論

作者其他優質文章

正在加載中
軟件工程師
手記
粉絲
1.6萬
獲贊與收藏
901

關注作者,訂閱最新文章

閱讀免費教程

感謝您的支持,我會繼續努力的~
掃碼打賞,你說多少就多少
贊賞金額會直接到老師賬戶
支付方式
打開微信掃一掃,即可進行掃碼打賞哦
今天注冊有機會得

100積分直接送

付費專欄免費學

大額優惠券免費領

立即參與 放棄機會
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號

舉報

0/150
提交
取消