String.raw()

ES6 还为原生的 String 对象,提供了一个raw()方法。该方法返回一个斜杠都被转义(即斜杠前面再加一个斜杠)的字符串,往往用于模板字符串的处理方法。

  1. String.raw`Hi\n${2+3}!`
  2. // 实际返回 "Hi\\n5!",显示的是转义后的结果 "Hi\n5!"
  3. String.raw`Hi\u000A!`;
  4. // 实际返回 "Hi\\u000A!",显示的是转义后的结果 "Hi\u000A!"

如果原字符串的斜杠已经转义,那么String.raw()会进行再次转义。

  1. String.raw`Hi\\n`
  2. // 返回 "Hi\\\\n"
  3. String.raw`Hi\\n` === "Hi\\\\n" // true

String.raw()方法可以作为处理模板字符串的基本方法,它会将所有变量替换,而且对斜杠进行转义,方便下一步作为字符串来使用。

String.raw()本质上是一个正常的函数,只是专用于模板字符串的标签函数。如果写成正常函数的形式,它的第一个参数,应该是一个具有raw属性的对象,且raw属性的值应该是一个数组,对应模板字符串解析后的值。

  1. // `foo${1 + 2}bar`
  2. // 等同于
  3. String.raw({ raw: ['foo', 'bar'] }, 1 + 2) // "foo3bar"

上面代码中,String.raw()方法的第一个参数是一个对象,它的raw属性等同于原始的模板字符串解析后得到的数组。

作为函数,String.raw()的代码实现基本如下。

  1. String.raw = function (strings, ...values) {
  2. let output = '';
  3. let index;
  4. for (index = 0; index < values.length; index++) {
  5. output += strings.raw[index] + values[index];
  6. }
  7. output += strings.raw[index]
  8. return output;
  9. }