编程语言
首页 > 编程语言> > javascript – 如何从标记函数调用本机es6模板字符串替换?

javascript – 如何从标记函数调用本机es6模板字符串替换?

作者:互联网

我正在为模板文字编写一个es6标记函数,它首先检查字符串中的条件,如果找不到条件,则仅解释模板文字,就好像它是未标记的一样.我很好奇,如果从我的标签功能,有一种方法来调用浏览器的本机模板文字函数(我认为它比我自己实现的函数更快). Bonue:有了这个,就不可能有标签组合的机会,例如htmlEscape(unindentfoobar);

例如.

function dumbTag(strs, ...vals) {
    vals = vals.map((val,i) =>
            (i % 2 == 0 ? 'even:' : 'odd:')+val);
    return String.template(strs, ...vals);
}

我自己实现的功能 – 是否有更快的方式/方式来调用浏览器的功能?

function template(strs, ...vals) {
    let result = strs[0];
    for (let [i,val] of vals.entries()) {
        result += val;
        result += strs[i+1];
    }
    return result;
}

解决方法:

没有这样的内置函数 – 未标记的模板文字只是直接评估为字符串.

is there a faster way?

这在很大程度上取决于实施.如果您使用的是转换器,我会避免使用rest参数,迭代器和for循环:

function template(strs) {
    var result = strs[0];
    for (var i=1; i < strs.length; i++) {
        result += arguments[i];
        result += strs[i];
    }
    return result;
}

标签:template-literals,javascript,ecmascript-6,variadic-templates
来源: https://codeday.me/bug/20190929/1831586.html