如何理解JavaScript中的标签模板字符串?

来源:AI教程网作者:越南程序员头衔:程序员
导读:本期聚焦于小伙伴创作的《如何理解JavaScript中的标签模板字符串?》,敬请观看详情,探索知识的价值。以下视频、文章将为您系统阐述其核心内容与价值。如果您觉得《如何理解JavaScript中的标签模板字符串?》有用,将其分享出去将是对创作者最好的鼓励。

标签模板字符串是JavaScript ES6引入的模板字符串的进阶用法,它允许我们把模板字符串和一个函数结合使用,让函数可以接收模板字符串的各个部分作为参数进行处理,实现更灵活的字符串操作逻辑。

如何理解JavaScript中的标签模板字符串?

标签模板字符串的基本结构

标签模板字符串的写法是把一个函数名放在模板字符串的前面,函数名就是所谓的标签,模板字符串的内容会作为函数的输入参数被处理。基本结构如下:

// 定义标签函数
function tagFunction() {
  console.log(arguments);
}

// 使用标签模板字符串
const name = '张三';
const age = 20;
tagFunction`我叫${name},今年${age}岁`;

这里tagFunction就是标签,后面的模板字符串是它的输入,执行这段代码后,标签函数会接收到拆分后的参数。

标签函数的参数规则

标签函数的第一个参数是一个数组,包含模板字符串中所有没有被变量替换的静态文本部分,后面的参数依次是模板字符串中每个插入的表达式的值。我们可以通过下面的例子来验证这个规则:

function printArgs(strings, ...values) {
  console.log('静态文本数组:', strings);
  console.log('表达式值:', values);
}

const a = 10;
const b = 20;
printArgs`第一个数:${a},第二个数:${b},总和是${a + b}`;

执行上面的代码,控制台会输出:

静态文本数组: ["第一个数:", ",第二个数:", ",总和是", ""]
表达式值: [10, 20, 30]

可以看到静态文本数组的长度永远比表达式值的数量多1,最后一个静态文本是模板字符串末尾的空字符串,如果模板字符串末尾没有内容,就会是空字符串。

自定义标签函数的实现

我们可以根据自己的需求实现标签函数,比如实现一个把模板里的表达式值都乘以2的标签函数:

function doubleValue(strings, ...values) {
  let result = '';
  for (let i = 0; i < strings.length; i++) {
    result += strings[i];
    if (i < values.length) {
      // 如果是数字就乘以2,否则原样拼接
      result += typeof values[i] === 'number' ? values[i] * 2 : values[i];
    }
  }
  return result;
}

const num1 = 5;
const num2 = 8;
const str = doubleValue`数字一:${num1},数字二:${num2}`;
console.log(str); // 输出:数字一:10,数字二:16

常见应用场景

1. 防止XSS攻击的HTML转义

在处理用户输入的内容拼接HTML时,可以使用标签模板字符串自动转义特殊字符,避免XSS风险:

function safeHtml(strings, ...values) {
  const escape = (str) => {
    return String(str)
      .replace(/&/g, '&amp;')
      .replace(/</g, '&lt;')
      .replace(/>/g, '&gt;')
      .replace(/"/g, '&quot;')
      .replace(/'/g, '&#39;');
  };
  let result = '';
  for (let i = 0; i < strings.length; i++) {
    result += strings[i];
    if (i < values.length) {
      result += escape(values[i]);
    }
  }
  return result;
}

const userInput = '<script>alert("恶意代码")</script>';
const html = safeHtml`
${userInput}
`; console.log(html); // 输出:<div>&lt;script&gt;alert(&quot;恶意代码&quot;)&lt;/script&gt;</div>

2. 国际化字符串处理

可以实现根据当前语言环境替换模板中的占位符的标签函数:

const i18nMap = {
  zh: { hello: '你好', name: '姓名' },
  en: { hello: 'Hello', name: 'Name' }
};
let currentLang = 'zh';

function i18n(strings, ...keys) {
  let result = '';
  for (let i = 0; i < strings.length; i++) {
    result += strings[i];
    if (i < keys.length) {
      result += i18nMap[currentLang][keys[i]] || keys[i];
    }
  }
  return result;
}

const userName = '李四';
console.log(i18n`${'hello'},你的${'name'}是${userName}`);
// 当前语言是zh时输出:你好,你的姓名是李四
currentLang = 'en';
console.log(i18n`${'hello'},你的${'name'}是${userName}`);
// 输出:Hello,你的Name是李四

注意事项

  • 标签函数的第一个参数数组有一个raw属性,里面保存的是模板字符串的原始字符串,也就是没有处理转义字符的内容,比如n会保持为两个字符而不是换行符。
  • 标签模板字符串中的表达式可以是任何有效的JavaScript表达式,包括函数调用、运算式等。
  • 标签函数的返回值没有限制,可以是字符串,也可以是其他任意类型,根据实际需求决定。

JavaScript标签模板字符串模板字符串函数调用修改时间:2026-06-18 18:36:35

免责声明:​ 已尽一切努力确保本网站所含信息的准确性。网站内容多为原创整理与精心编撰,观点力求客观中立。本站旨在免费分享,内容仅供个人学习、研究或参考使用。若引用了第三方作品,版权归原作者所有。如内容涉及您的权益,请联系我们处理。
内容垂直聚焦
专注技术核心技术栏目,确保每篇文章深度聚焦于实用技能。从代码技巧到架构设计,为用户提供无干扰的纯技术知识沉淀,精准满足专业提升需求。
知识结构清晰
覆盖从开发到部署的全链路。AI、前端、编程、数据库、服务器、建站、系统层层递进,构建清晰学习路径,帮助用户系统化掌握开发与运维所需的核心技术。
深度技术解析
拒绝泛泛而谈,深入技术细节与实践难点。无论是数据库优化还是服务器配置,均结合真实场景与代码示例进行剖析,致力于提供可直接应用于工作的解决方案。
专业领域覆盖
精准对应开发生命周期。从前端界面到后端编程,从数据库操作到服务器运维,形成完整闭环,一站式满足全栈工程师和运维人员的技术需求。
即学即用高效
内容强调实操性,步骤清晰、代码完整。用户可根据教程直接复现和应用于自身项目,显著缩短从学习到实践的距离,快速解决开发中的具体问题。
持续更新保障
专注既定技术方向进行长期、稳定的内容输出。确保各栏目技术文章持续更新迭代,紧跟主流技术发展趋势,为用户提供经久不衰的学习价值。