JavaScript模板字符串是ES6引入的反引号语法,支持变量插值(${})、多行书写及标签函数,提升可读性与安全性,运行时性能与普通拼接基本一致。

JavaScript模板字符串(Template Literal)是ES6引入的一种字符串字面量语法,用反引号 ` 包裹,支持嵌入表达式、多行书写和字符串插值。它不是“更高级”的字符串类型,而是语法层面的增强,让字符串操作更直观、更安全、更灵活。
支持变量插值,不用拼接
普通字符串要用加号(+)或String.concat()拼接变量,容易出错且可读性差:
❌ 普通字符串:
const name = '小明'; const age = 25;
const msg = '你好,我叫' + name + ',今年' + age + '岁。';
✅ 模板字符串:const msg = `你好,我叫${name},今年${age}岁。`
插值部分写在${}里,可以是变量、函数调用、甚至简单运算:`${a > b ? '大' : '小'}`、${getName().toUpperCase()} 都可以直接用。
天然支持多行文本
普通字符串换行必须用\n加+连接,或使用反斜杠续行(易出错):
const html = '';
模板字符串直接换行,缩进和空格都会保留(适合HTML、SQL、配置等):
const html = ``;
标题
内容
如果不想保留换行和空格,可用.trim()或标签函数处理。
可配合标签函数实现高级功能
模板字符串开头可以加一个函数名,称为“标签模板”(Tagged Template):
html`
这个html函数会收到字符串数组和插值结果作为参数,可用于自动转义HTML、高亮代码、国际化、SQL防注入等。例如:
- 安全渲染:把
${userInput}自动做HTML转义 -
本地化:根据当前语言替换
${t('submit')} - 样式处理:像styled-components那样解析CSS字符串
没有运行时性能劣势
有人担心模板字符串更“重”,其实现代引擎(V8、SpiderMonkey)已对它做了深度优化。插值在编译阶段就确定结构,运行时开销和字符串拼接基本一致。真正影响性能的是频繁创建大量字符串对象——这跟用不用模板字符串无关,而取决于你的逻辑设计。











