11

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

例如。

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;
}
4

4 回答 4

7

您可以(ab)使用String.raw(唯一的内置标签)用于此目的:

function doNothingTag() {
  arguments[0] = { raw: arguments[0] };
  return String.raw(...arguments);
}

// Or in a more modern style:
const doNothingTag = (strings, ...rest) => String.raw({ raw: strings }, ...rest);

doNothingTag`It works!`
// "It works!"

doNothingTag`Even\nwith\nescape\nsequences!`
// "Even
// with
// escape
// sequences!"

这本质上只是欺骗String.raw认为转义解释的字符串是原始版本。

于 2017-05-30T05:49:16.623 回答
2

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

有更快的方法吗?

这在很大程度上取决于实施。如果您使用的是转译器,我会避免使用剩余参数、迭代器和for of循环:

function template(strs) {
    var result = strs[0];
    for (var i=1; i < strs.length; i++) {
        result += arguments[i];
        result += strs[i];
    }
    return result;
}
于 2016-07-05T19:01:40.627 回答
1

我也想知道是否有这样的原生功能。与此同时,这是我使用的:

const tag = ([head, ...tail], ...args) => tail.reduce((a, b, i) => a + args[i] + b, head);
于 2021-06-11T09:55:25.443 回答
0

一个简短的实现可以通过使用Array.prototype.flatMap()这样的来完成:

const defaultTag = (strs, ...vals) =>
  strs.flatMap((x, i) => [x, i < vals.length ? vals[i] : undefined]).join('');

const name = 'Some name';
const age = 32;

console.log(defaultTag`Hi my name is ${name}, and I'm ${age} years old!`);

于 2020-12-07T21:38:50.630 回答