为了账号安全,请及时绑定邮箱和手机立即绑定

模板字面量修订 • 探索 ES2018 和 ES2019

标签:
JavaScript

模板字面量修订』这个ECMAScript提案由Tim Disney 负责,为标签化模板字面量内部提供更多的语法自由。

标签函数和转义序列

你可以提前在模板文本之前创建一个函数,借助标签化模板字面量,对这个函数进行调用:

> String.raw\u{4B}'\\u{4B}'

String.raw是一个所谓的标签函数。在模板字面量中标签函数可以接收两个版本的固定字符串片段(模板字符串):

  • Cooked:被解释的转义序列。\u{4B} 转成『K』。

  • Raw:正常文本的转义序列。\u{4B} 转成 『\u{4B}』。

通过下面的标签函数说明这是如何工作的:

function tagFunc(tmplObj,substs){    return {
        Cooked: temlObj,
        Raw: temlObj.raw,
    };
}

使用标签函数:

> tagFunc\u{4B};
{Cooked: ['K'],Raw: ['\\u{4B}']}

有关标签函数的更多内容,请参考『搜https://www.zcfy.cc/article/template-literal-revision-exploring-es2018-and-es2019索ES6』中的『实现标签函数』。

问题:反斜杠后有些文本是不合法的

问题是,即使使用raw版本,ES2016中模板字面量也没有完全的自由化,经过反斜杠后,一些字符序列不再合法:

  • \u 开始Unicode转义,它必须看起来像\u{1F4A4}或\u004B。

  • \x 开始十六进制转义,它必须看起来像\x4B。

  • \加数字开始八进进制转义(如\141)。模板文本和严格模式字符串文本中禁止使用八进制转义符。

这可以防止标签化的模板字面量,例如:

latex\unicode
windowsPathC:\uuu\xxx\111

解决方案

解决方案是放弃与转义序列相关的所有语法限制,然后,非法转义序列只是在原始表示中逐字显示。但是cooked应该怎么表示呢?具有非法转义序列的每个模板字符串在cooked数组中都是未定义的元素:

> tagFunc\uu ${1} \xx{Cooked: [undefined,undefined],Raw:['\\uu','\\xx']}

译文出处

点击查看更多内容
TA 点赞

若觉得本文不错,就分享一下吧!

评论

作者其他优质文章

正在加载中
  • 推荐
  • 评论
  • 收藏
  • 共同学习,写下你的评论
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦
今天注册有机会得

100积分直接送

付费专栏免费学

大额优惠券免费领

立即参与 放弃机会
意见反馈 帮助中心 APP下载
官方微信

举报

0/150
提交
取消