es6 对字符串的扩展

js底层采用的是utf-16的编码方式,平时我们可能对utf-8更熟悉一些,他们的区别在于utf-16是采用16位,用两字节来表示一个字符(Unicode码点在\u0000~\uFFFF之间的字符),而utf-8是8位,会根据情况来用一个字节、两个字节,最多不超过三个字节来表示一个字符。

因为utf-16是用两个字节表示,所以大于两个字节的字符,用es5的方法就会出错,例如

这里写图片描述
这个字需要四个字节来存储,js把它识别为两个字符,es5的方法没法来正确处理它,es6为了解决类似的问题,提出了配套的新方法,codePointAt代替charCodeAtat代替charAtfromCodePoint代替fromCharCode

他们的用法与原来的基本一样

但有一点值得注意的是,es6只算是一种语法糖,并不会改变js底层utf-16编码的本质,只是可以在处理这些问题的时候可以把这四个字节看成一个字,但当我们取长度,或者取某一位时,还是会以两个字节为一个长度,像这样:
这里写图片描述
取第零位时,已经正确的把这个字转为了10进制码点,第一位表示的是它的后两个字节,第二位才是它后面的a
这样看起来不友好,我们可以配合es6的for…of方法
这里写图片描述
这样看起来就合理一些。
东西总是要配套的,所以es6跟字符串相关的方法都做了修正,解决了超过两字符的问题,我们尽量使用es6的方法

字符串相关的新方法还有很多,像includes,startsWith,endsWith,padStart,padEnd等。有兴趣的点这里阮一峰es6-字符串的扩展

### ES6 模板字符串传参 在 JavaScript 中,ES6 引入了模板字符串的功能,允许更方便地创建多行字符串以及嵌入表达式。当涉及到向模板字符串传递参数时,可以使用 `${expression}` 的形式将变量或表达式的值插入到字符串中[^2]。 对于简单的插值需求: ```javascript const name = "Alice"; const greeting = `Hello, ${name}`; console.log(greeting); // Hello, Alice ``` 除了基本的数据绑定外,在某些场景下可能还需要处理逻辑判断或者循环结构等内容。由于标准的模板字符串并不直接支持这些功能,因此可以通过定义自定义标签函数的方式来扩展其能力[^3]。 下面是一个带有条件渲染的例子: ```javascript function conditionalTag(strings, ...values) { let result = ''; values.forEach((value, index) => { if (value !== undefined && value !== null && value !== '') { result += strings[index] + value; } else { result += strings[index]; } }); return result + strings[strings.length - 1]; } let user = { name: 'Bob', age: '' }; let bio = conditionalTag`Name: ${user.name}, Age: ${user.age}`; console.log(bio); // Name: Bob, ``` 此例子展示了通过构建一个名为 `conditionalTag` 的标签函数实现了仅当给定属性存在有效值时才将其加入最终输出的能力。 #### 处理复杂情况下的数据展示 考虑到更为复杂的业务逻辑,比如列表项遍历,则通常会结合其他库(如 lodash 或者专门的模板引擎)完成此类任务;不过也可以尝试编写自己的解决方案来满足特定的需求。 例如,这里给出了一种模拟 Mustache 和 Nunjucks 风格语法的方式来进行书籍集合的渲染: ```javascript var myBooks = [ { title: 'JavaScript The Good Parts', author: 'Douglas Crockford' }, { title: 'Eloquent JavaScript', author: 'Marijn Haverbeke' }]; function hashTemplate(literals, ...placeholders) { const template = literals.join('${}'); placeholders.forEach((placeholder, i) => template.replace(`#${i}`, placeholder)); // 此处简化处理,实际应解析并执行完整的模板指令集 return eval('`' + template.replaceAll('#{', '${') + '`'); } var libraryHtml = hashTemplate` <ul> #for book in ${JSON.stringify(myBooks)} <li><i>${book.title}</i> by ${book.author}</li> #/for </ul>`; console.log(libraryHtml); /* 输出类似于: <ul> <li><i>JavaScript The Good Parts</i> by Douglas Crockford</li> <li><i>Elegant JavaScript</i> by Marijn Haverbeke</li> </ul>*/ ``` 上述代码片段演示了一个基于纯虚构模板语言的概念验证版本,其中包含了对数组元素迭代的支持。需要注意的是这只是一个简化的实现方式,并未完全遵循任何现有的模板规范。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值