极简三分钟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%反斜杠
包含反斜杠文本 手动转义\ 直接书写`` 避免转义混淆
嵌套模板 字符串拼接 直接嵌套 提升可读性

牢记

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

相关推荐
别看我只是一直狼12 分钟前
从观察者模式到 RxJS:让复杂的异步逻辑变得优雅又舒服
javascript
花间相见13 分钟前
【终端效率工具01】—— Yazi:Rust 编写的现代化终端文件管理器,告别繁琐操作
前端·ide·git·rust·极限编程
|晴 天|23 分钟前
我如何用Vue 3打造一个现代化个人博客系统(性能提升52%)
前端·javascript·vue.js
风止何安啊31 分钟前
网页都知道要双向握手才加载!从 URL 到页面渲染,单向喜欢连 DNS 都解析不通
前端·javascript·面试
太极OS36 分钟前
给 AI Skill 做 CI/CD:GitHub + ClawHub + Xiaping 同步发布实战
前端
你_好37 分钟前
Chrome 内置了 AI 工具协议?WebMCP 抢先体验 + 开源 DevTools 全解析
前端·mcp
GISer_Jing37 分钟前
LangChain.js + LangGraph.js 前端AI开发实战指南
前端·javascript·langchain
正在发育ing__41 分钟前
从源码看vue的key和状态错乱的patch
前端
木心术142 分钟前
TypeScript实战进阶:从基础类型到高级类型编程
javascript·ubuntu·typescript
Hello--_--World1 小时前
浏览器同源策略与跨域问题
javascript