极简三分钟ES6 - ES9中字符串扩展

在ES9中主要是放宽了对模板字符串文字限制

模板字符串的「紧身衣」

在ES9之前,模板字符串遇到转义序列时会有严格限制

js 复制代码
// ES8及之前会报错 
const path = `C:\new\templates\`;  
// 错误!因为`\n`和`\t`被解释为换行符和制表符 

这就像在严格安检通道

  • 所有``开头的字符必须符合标准转义规则(如\n换行、\t制表符)
  • 非标准格式(如\x\u不完整)直接报错

ES9的「宽松模式」

ES9引入标记模板字面量的宽松解析规则

js 复制代码
// ES9中安全使用 
const path = String.raw`C:\new\templates\`;   
// 成功输出 "C:\new\templates\"

允许非常规转义序列

js 复制代码
console.log(`\x`);      // ES9输出 "\\x"(保留原样)
console.log(`\u{61}`);  // 输出 "a"(正常解析Unicode)

支持嵌套模板字符串

js 复制代码
// 多层模板嵌套(如生成HTML)
const html = `
  <div>
    ${`<span>${userName}</span>`}
  </div>
`;

一些常见的使用场景

Windows路径处理

js 复制代码
// 文件路径安全书写 
const configPath = `C:\Program Files\app\config.json`;   
// 无需写成:C:\\Program Files\\app\\config.json  

正则表达式简化

js 复制代码
// 匹配反斜杠的正则 
const regex = new RegExp(`\d+\\\.\\d+`);  
// 无需写成:\\d+\\\.\\d+

代码生成工具

js 复制代码
// 生成带转义字符的代码 
const code = `console.log("Hello\\nWorld");`;   
// 输出:console.log("Hello\nWorld"); 

与传统方案相比

场景 旧版方案 ES9方案 优势
书写Windows路径 C:\\Program Files C:\Program Files 减少50%反斜杠
包含反斜杠文本 手动转义\ 直接书写`` 避免转义混淆
嵌套模板 字符串拼接 直接嵌套 提升可读性

牢记

解放转义 允许非常规转义序列存在,解放嵌套 支持模板多层嵌套结构,解放创作特殊字符处理更自由

相关推荐
king王一帅2 小时前
Incremark Solid 版本上线:Vue/React/Svelte/Solid 四大框架,统一体验
前端·javascript·人工智能
智航GIS7 小时前
10.4 Selenium:Web 自动化测试框架
前端·python·selenium·测试工具
前端工作日常7 小时前
我学习到的A2UI概念
前端
徐同保7 小时前
为什么修改 .gitignore 后还能提交
前端
一只小bit7 小时前
Qt 常用控件详解:按钮类 / 显示类 / 输入类属性、信号与实战示例
前端·c++·qt·gui
Mr -老鬼8 小时前
前端静态路由与动态路由:全维度总结与实践指南
前端
Nan_Shu_6148 小时前
学习: Threejs (1)
javascript·学习
颜酱9 小时前
前端必备动态规划的10道经典题目
前端·后端·算法
wen__xvn9 小时前
代码随想录算法训练营DAY10第五章 栈与队列part01
java·前端·算法
Van_Moonlight9 小时前
RN for OpenHarmony 实战 TodoList 项目:加载状态 Loading
javascript·开源·harmonyos