04. 字符串的扩展

字符串的扩展

原书作者:阮一峰
原书地址:ECMASript 6入门

  • 基本字符表示
  • 字符串新方法
  • 模板字符串

1. 基本字符表示

  • 字符的unicode表示法
    • JS允许采用\uxxxx形式来表示一个字符,其中xxxx为字符的unicode码
    "\u0061"
    // "a"
    
    • 超过\u0000-\uFFFF的字符使用两个双字节形式表示
    "\uD842\uDFB7"
    // "𠮷"
    
    • 码点放入大括号,可以正确解读字符
    "\u20BB7"
    // " 7" (理解为\u20BB+7,而\u20BB不可打印)
    "\u{20BB7}"
    // "𠮷"
    "\u{41}\u{42}\u{43}"
    // "ABC"
    
    • 包括这种方法,JS有6中字符表示法
    '\z' === 'z'  // true
    '\172' === 'z' // true
    '\x7A' === 'z' // true
    '\u007A' === 'z' // true
    '\u{7A}' === 'z' // true
    

2. 字符串新方法

  • codePointAt
    • 功能:可以返回一个字符的码点(能够处理4字节字符,而charCodeAt不行)
    var s = "𠮷";
    s.length // 2
    s.charAt(0) // ''
    s.charAt(1) // ''
    s.charCodeAt(0) // 55362
    s.charCodeAt(1) // 57271
    
    let s = '𠮷a';
    s.codePointAt(0) // 134071
    s.codePointAt(1) // 57271
    s.codePointAt(2) // 97
    
    • 上述例子证明,在参数不恰当时仍然得不到想要的结果,可以使用for来解决
    let s = '𠮷a';
    for (let ch of s) {
      console.log(ch.codePointAt(0).toString(16));
    }
    // 20bb7
    // 61
    
    • 该方法可以测试一个字符是双字节还是四字节
    function is32Bit(c) {
      return c.codePointAt(0) > 0xFFFF;
    }
    
    is32Bit("𠮷") // true
    is32Bit("a") // false
    
  • String.fromCodePoint
    • 功能:返回码点对应的字符(弥补fromCharCode不识别大于0xFFFF字符的不足)
    String.fromCharCode(0x20BB7)
    // "ஷ"
    String.fromCodePoint(0x20BB7)
    // "𠮷"
    
    • 接收多个参数时,返回对应的字符串
    String.fromCodePoint(0x78, 0x1f680, 0x79) === 'x\uD83D\uDE80y'
    // true
    
  • at (提案)
    • 功能:返回指定位置字符(支持四字节字符)
    '𠮷'.charAt(0) // "\uD842"
    '𠮷'.at(0) // "𠮷"
    
  • normalize
    • 功能:合成字符(O(\u004F)和ˇ(\u030C)合成Ǒ(\u004F\u030C))
    '\u01D1'.normalize() === '\u004F\u030C'.normalize()
    
  • includes(),startsWith(),endsWith()
    • includes() 返回布尔值,表示是否找到了参数字符串
    • startsWith() 返回布尔值,表示参数字符串是否在原字符串头部
    • endsWith() 返回布尔值,表示字符串是否在原字符串尾部
    let s = 'Hello world!';
    
    s.startsWith('Hello') // true
    s.endsWith('!') // true
    s.includes('o') // true
    
    s.startsWith('world', 6) // true
    s.endsWith('Hello', 5) // true
    s.includes('Hello', 6) // false
    // 支持第二个参数,endsWith与其他两个不同,
    // 它针对前n个字符,其他两个则从第n个开始到字符串结尾
    
  • repeat()
    • repeat返回一个新字符串,表示将原字符串重复n次
    'x'.repeat(3) // "xxx"
    'hello'.repeat(2) // "hellohello"
    'na'.repeat(0) // ""
    
  • padStart(), padEnd() (ES2017)
    • padStart用于首部补全,padEnd用于尾部补全
    'x'.padStart(5, 'ab') // 'ababx'
    'x'.padStart(4, 'ab') // 'abax'
    
    'x'.padEnd(5, 'ab') // 'xabab'
    'x'.padEnd(4, 'ab') // 'xaba'
    
    'x'.padStart(4) // '   x'
    'x'.padEnd(4) // 'x   '
    
  • String.raw
    • 功能:用来充当模板字符串的处理函数,返回一个斜杠都被转义(即斜杠前面再加一个斜杠)的字符串,对应于替换变量后的模板字符串
    String.raw`Hi\n${2+3}!`;
    // "Hi\\n5!"
    
    String.raw`Hi\u000A!`;
    // 'Hi\\u000A!'
    
    String.raw`Hi\\n`
    // "Hi\\n"
    // 原字符串的斜杠已经转义,则raw不做处理
    

3. 模板字符串

模板字符串(templatestring)是增强版的字符串,用反引号(`)标识,
它可以当作普通字符串使用,也可以用来定义多行字符串,或者在字符串中嵌入变量

// 传统模板
$('#result').append(
  'There are <b>' + basket.count + '</b> ' +
  'items in your basket, ' +
  '<em>' + basket.onSale +
  '</em> are on sale!'
);

// ES6 写法
$('#result').append(`
  There are <b>${basket.count}</b> items
   in your basket, <em>${basket.onSale}</em>
  are on sale!
`);

模板字符串可以紧跟在一个函数名后面,该函数将被调用来处理这个模板字符串,这称为“标签模板”功能

alert`123`
// 等同于
alert(123)

let a = 5;
let b = 10;
tag`Hello ${ a + b } world ${ a * b }`;
// 等同于
tag(['Hello ', ' world ', ''], 15, 50);
// 如果模板字符里面有变量,就不是简单的调用了
// 而是会将模板字符串先处理成多个参数,再调用函数
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,456评论 5 477
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,370评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,337评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,583评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,596评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,572评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,936评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,595评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,850评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,601评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,685评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,371评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,951评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,934评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,167评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 43,636评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,411评论 2 342

推荐阅读更多精彩内容