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

JavaScript模板字符串(Template Literal)是ES6引入的一种字符串字面量语法,用反引号 ` 包裹,支持嵌入表达式、多行书写和字符串插值。它不是“更高级”的字符串类型,而是语法层面的增强,让字符串操作更直观、更安全、更灵活。
普通字符串要用加号(+)或String.concat()拼接变量,容易出错且可读性差:
❌ 普通字符串:
const name = '小明'; const age = 25;<br>const msg = '你好,我叫' + name + ',今年' + age + '岁。';
✅ 模板字符串:const msg = `你好,我叫${name},今年${age}岁。`
插值部分写在${}里,可以是变量、函数调用、甚至简单运算:`${a > b ? '大' : '小'}`、${getName().toUpperCase()} 都可以直接用。
普通字符串换行必须用\n加+连接,或使用反斜杠续行(易出错):
const html = '<div>' +<br> '<h2>标题</h2>' +<br> '<p>内容</p><p><span>立即学习</span>“<a href="https://pan.quark.cn/s/c1c2c2ed740f" style="text-decoration: underline !important; color: blue; font-weight: bolder;" rel="nofollow" target="_blank">Java免费学习笔记(深入)</a>”;</p>' +<br> '</div>';
模板字符串直接换行,缩进和空格都会保留(适合HTML、SQL、配置等):
const html = `<div><br> <h2>标题</h2><br> <p>内容</p><br></div>`;
如果不想保留换行和空格,可用.trim()或标签函数处理。
模板字符串开头可以加一个函数名,称为“标签模板”(Tagged Template):
html`<div class="${cls}">${content}</div>`;
这个html函数会收到字符串数组和插值结果作为参数,可用于自动转义HTML、高亮代码、国际化、SQL防注入等。例如:
${userInput}自动做HTML转义${t('submit')}
有人担心模板字符串更“重”,其实现代引擎(V8、SpiderMonkey)已对它做了深度优化。插值在编译阶段就确定结构,运行时开销和字符串拼接基本一致。真正影响性能的是频繁创建大量字符串对象——这跟用不用模板字符串无关,而取决于你的逻辑设计。
以上就是javascript模板字符串是什么_它比普通字符串好在哪的详细内容,更多请关注php中文网其它相关文章!
java怎么学习?java怎么入门?java在哪学?java怎么学才快?不用担心,这里为大家提供了java速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号