日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

JavaScript開發中需要搞懂的字符編碼總結

瀏覽:231日期:2022-06-01 10:14:22
目錄
  • 字符集和字符編碼
  • ASCII
  • 字符集的發展歷史
  • Unicode
    • UTF-8
    • UTF-16
    • 比較
  • 前端開發中的編碼
    • 字符串長度計算
    • 組合字符的長度
    • 多碼元字符操作
    • 正則中的 u 修飾符
    • 轉義字符
  • 常用API
    • 處理碼點和字符
    • TextEncoder
    • String.prototype.normalize()
    • URL的UTF8編解碼

字符集和字符編碼

字符集就是字符的集合,如常見的 ASCII字符集,GB2312字符集,Unicode字符集等。這些不同字符集之間最大的區別是所包含的字符數量的不同。

字符編碼則代表字符集的實際編碼規則,是用于計算機解析字符的,如 GB2312,GBK,UTF-8 等。字符編碼的本質就是如何使用二進制字節來表示字符的問題。

字符集和編碼是一對多的關系,同一字符集可能有多種字符編碼,如Unicode字符集就有 UTF-8,UTF-16 等。

在前端開發中,Javascript程序是使用Unicode字符集,Javascript源碼文本通常是基于UTF-8編碼。
但JS代碼中的字符串類型是UTF-16編碼的,這也是為什么會碰到api接口返回字符串在前端出現亂碼,因為多數后臺服務都使用utf-8編碼,前后編碼方式不一致。

說起字符集的發展歷程,可以總結為一句話:幾乎都是對ASCII字符集的擴展。

ASCII

我們知道,計算機是使用二進制來處理信息的。
其中,每一個二進制位(bit)有 0和1 兩種狀態。一個字節(byte)則有8個二進制位,可以有256種狀態。

而ASCII就是基于拉丁字母、主要用于顯示英文的一種單字節字符集,它的編碼和字符是一一對應的,因為它就是使用一個字節8個二進制位來表示,不會超過256個字符。

標準的ASCII字符總計有128個字符(2^7),其中前面32個控制字符,后面96個是可打印字符,包括常用的大小寫字母數字標點符號等。因為只占用了一個字節的后7位,那字節的最高位一般設置為0。

"a".charCodeAt() // 97
"A".charCodeAt() // 65
"9".charCodeAt() // 57
".".charCodeAt() // 46

如上,每個字符會對應一個編碼(使用數字標識),總共會從0-128。完整的ASCII碼表,網上很容易找到。

通過ASCII碼表,我們發現,小寫字母并沒有和大寫字母挨著排序?
這是為了方便大小寫之間的轉換, A 排在 65(64 + 1) 位,而 a 排在 97(64 + 32 + 1) 位。

65 ^ 32 = 97
// A ^ 32 = a

字符集的發展歷史

ASCII是幾乎所有字符集的基礎。

標準的ASCII碼最多只能標識128個字符,歐美國家可以很好的使用,但其他國家的字符變多,自然就不夠用了。

這個時候,最高位就開始被惦記上,通過擴展ASCII碼的最高位,又能滿足用于特殊符號的一些國家的需求,這種就是擴展ASCII碼。

但是亞非拉更多非拉丁語系的國家,字符成千上萬,只能使用新的方式。

如中文,就又進行了擴展,小于127的字符的意義與標準ASCII碼相同,當需要標識漢字時,使用2個字節,每個字節都大于127。這種多字節字符集即GB2312,后續因為不斷的擴展,如繁體字和各種符號,甚至少數民族的語言符號等等,又使用了包括GBK等不同字符集。

因此,很多國家都制定了自己的編碼字符集,基本都是在ASCII的基礎上進行的。

各字符集雖然都能夠兼容標準ASCII碼,但在使用交流上的不便是顯而易見的,亂碼也是隨處可見。為了解決這種各自為戰的問題,Unicode字符集就誕生了。

Unicode

Unicode是國際組織制定的,用于收納世界上所有文字和符號的字符集方案。

前128個字符同ASCII一樣,進行擴充后,使用數字0-0x10FFFF來映射這些字符,最多可以有1114112個字符。目前仍然只使用了其中的一小部分。
Unicode一般使用兩個字節來表示一個字符。

碼點

  • Unicode 規定了每個字符的數字編號,這個編號被稱為 碼點(code point)
  • 碼點以 U+hex 的形式表示,U+是代表Unicode的前綴,而 hex 是一個16進制數。取值范圍是從 U+0000 到 U+10FFFF。
  • 每個碼點對應一個字符,絕大部分的常見字符在最前面的 65536 個字符,范圍是 U+0000到U+FFFF。
  • 一般漢字的碼點區間為 U+2E80 - U+9FFF。

字符平面

  • 目前的Unicode分成了17個編組,也稱平面,每個平面有65536個碼點。
  • 第一個平面是基本多語言平面,范圍:U+0000 - U+FFFF,多數常見字符都在該區間。
  • 其他平面則為輔助平面,范圍:U+10000 到 U+10FFFF,如我們在網上常見 Emoji 表情。

碼元

  • 碼元(Code Unit)可以理解為對碼點進行編碼時的最小基本單元,碼元是一個整體。而字符編碼的作用就是將Unicode碼點轉換成碼元序列。
  • Unicode常用的編碼方式有 UTF-8 、UTF-16 和 UTF-32,UTF是Unicode TransferFormat的縮寫。
  • UTF-8是8位的單字節碼元,UTF-16是16位的雙字節碼元,UTF-32是32位的四字節碼元。
編碼方式碼元編碼后字節數UTF-88位1-4字節UTF-1616位2字節或者4字節UTF-3232位4字節

另外,為什么總看到使用十六進制數據來表示如碼點等各種數據呢?

因為,兩位的十六進制正好等于一個字節8位,0xff = 0b11111111。

UTF-8

UTF-8是一種可變長度的字符編碼方式。目前是使用 1 到 4 個字節來編碼字符。

是互聯網時代應用最廣的一種編碼方式,前端接觸的相對最多。

需要注意的是:漢字一般占3個字節,表情符號一般占4個字節。

UTF-8的編碼規則:

  • 1個字節的字符,第一位為0,后7位為碼點,與ASCII相同。
  • n個字節的字符,第一個字節前面 n 位都是1,n+1位是0,可據此判斷有幾個字節。后面的幾個字節都是 10 為開頭2位。

這里規定的都是前綴,對于字符的碼點,需要進行截取后依次放入除前綴外的其他位,所以UTF-8又被稱為前綴碼。

格式如下表:

字節數碼點位數碼點范圍編碼方式17U+0000~U+007F0×××××××211U+0080~U+07FF110××××× 10××××××316U+0800~U+FFFF1110×××× 10×××××× 10××××××421U+10000~U+10FFFF11110××× 10×××××× 10×××××× 10××××××

通過上表的編碼規則,我們就可以進行各種轉換了。

下面我們以一個中文字符的編碼轉換為例,如漢字 '好':

'好'的Unicode碼點:'好'.codePointAt() \\ 22909,結果是22909

22909在UTF-8的3字節數的編碼區間 U+0800 (2048) ~ U+FFFF (65535)

22909的二進制值:101100101111101,有15位

而3字節數的編碼需要16位,前面補0,根據表中規則分成3組:0101 100101 111101

依次填入對應的前綴:11100101 10100101 10111101,得到3個字節

將得到的三個字節轉成十六進制數據:E5 A5 BD,所以漢字 '好' 的UTF-8就是:E5 A5 BD

我們使用 encodeURI 進行驗證————encodeURI函數支持將中文進行 UTF-8 編碼:

encodeURI("好") // "%E5%A5%BD"

去除百分號,結果正好一致。

UTF-16

UTF-16的編碼方式:基本平面的字符占用 2 個字節(U+0000到U+FFFF),輔助平面的字符占用 4 個字節(U+010000到U+10FFFF)。
也就是說,UTF-16的編碼長度要么是2個字節要么是4個字節。當為2字節時,則實際上是與Unicode相同。

并且還有個原則,在Unicode基本多語言平面內,從U+D800到U+DFFF之間的碼點區間是不對應字符的。而UTF-16需要利用這塊碼位來對輔助平面的字符進行編碼。

它的具體規則:

碼點小于U+FFFF,基本字符,不需處理,直接使用,占兩個字節。

否則,拆分成兩個碼元,四個字節,cp表示碼點:

低位——((cp - 65536) / 1024) + 0xD800,值范圍是 0xD800~0xDBFF;

高位——((cp - 65536) % 1024) + 0xDC00,值范圍是 0xDC00~0xDFFF。

看下面的示例:

1.漢字 '好','好'.codePointAt() // 22909,碼點小于U+FFFF,直接進行十六進制轉換:579D。

2.表情符號 '

標簽: JavaScript
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
a日韩av网址| 欧美日韩黄网站| 午夜一级久久| 不卡中文一二三区| 亚洲欧美日韩精品一区二区| 在线一区视频| 亚洲精品中文字幕乱码| 日韩毛片在线| 久久先锋影音| 久久精品国产999大香线蕉| 久久狠狠婷婷| 美女网站久久| 亚洲免费中文| 欧美日韩亚洲国产精品| 国产99精品一区| 日本不卡免费高清视频在线| 中文字幕亚洲在线观看| 欧洲一级精品| 欧美日韩国产免费观看视频| 1024精品久久久久久久久| 国产精品毛片一区二区三区| 国产精品2023| 亚洲久久在线| 青青草精品视频| 亚洲午夜视频| 国产免费av国片精品草莓男男| www.九色在线| 在线综合视频| 美腿丝袜在线亚洲一区| 日韩欧美少妇| 91成人在线网站| 国产v日韩v欧美v| 亚洲一区激情| 国产欧美日韩| 国产日韩电影| 亚洲精品自拍| 亚洲精品日韩久久| 免费久久99精品国产自在现线| 国产精品一区免费在线| 亚洲a一区二区三区| 久久夜色精品| 亚洲精品激情| 欧美成人高清| 日韩黄色大片| 亚洲久草在线| 国产精品国产三级在线观看| 亚洲激情另类| 不卡一二三区| 欧美视频久久| 午夜宅男久久久| 亚洲免费福利| sm久久捆绑调教精品一区| 久久精品观看| 午夜久久免费观看| 亚洲男女av一区二区| 蜜臀av性久久久久蜜臀aⅴ流畅 | av免费不卡国产观看| 精品一区二区男人吃奶| 国产日韩一区二区三区在线播放| 久久久久九九精品影院| 欧美精品一区二区三区精品| 亚洲五月综合| 国产精品美女| 国产乱子精品一区二区在线观看| 国产成人精品亚洲线观看| 日韩一区二区三区免费| 日韩视频中文| 综合国产视频| 清纯唯美亚洲综合一区| 69精品国产久热在线观看| 91九色综合| 久久国产精品美女| 极品av在线| 一区二区三区四区在线看| 日韩中文字幕麻豆| 岛国av免费在线观看| 合欧美一区二区三区| 亚洲精品成人| 欧美成人精品三级网站| 综合激情一区| 99久久夜色精品国产亚洲1000部| 色8久久久久| 婷婷丁香综合| 日韩毛片视频| 国产精品激情电影| 亚洲影视一区| 毛片在线网站| 精品欧美日韩精品| 日韩中文一区二区| 日韩视频在线一区二区三区 | 欧美日韩一区二区三区视频播放| 久久亚洲不卡| 好吊一区二区三区| av免费不卡国产观看| 日本欧美一区二区| 精品日韩毛片| 欧美亚洲精品在线| 日本在线高清| 国产精选久久| 国产亚洲久久| 四虎在线精品| 99国产精品私拍| 久久精品国产久精国产爱| 青青草国产成人99久久| 快she精品国产999| 特黄特色欧美大片| 精品久久91| 你懂的亚洲视频| 日韩精品成人| 日韩一区精品| 久久久久国产| 欧美精品99| 亚洲精品国产精品粉嫩| 欧美激情视频一区二区三区免费 | 国产精品美女在线观看直播| 中文亚洲欧美| 激情五月综合网| 日韩精品不卡一区二区| 国产精品久久观看| 精品黄色一级片| 精品免费在线| 精品国产乱码久久久| 日韩国产在线观看| 国产精品久久久久久妇女 | 日韩区欧美区| 免费人成网站在线观看欧美高清| 国产综合婷婷| 影音先锋久久精品| 久久精品xxxxx| 日韩成人精品一区| 久热精品在线| 欧美激情在线精品一区二区三区| 激情国产在线| 国内自拍视频一区二区三区| 亚洲在线一区| 激情婷婷欧美| 国产精品欧美一区二区三区不卡| 国产亚洲一区| 国产精品第一国产精品| 久久中文字幕av一区二区不卡| 精品视频自拍| 亚洲精品影视| 青青国产精品| 激情国产在线| 久久精品国产精品亚洲毛片| 麻豆91精品91久久久的内涵| 欧美黄色一区| 精品国产亚洲一区二区三区大结局| 日韩精品国产欧美| 日韩精品三区四区| 欧美日韩1区| 日韩精品一区二区三区中文 | 亚洲成人不卡| 亚洲精品成人一区| 日韩伦理在线一区| 一本一道久久a久久| 免费中文字幕日韩欧美| 免费在线观看一区| 亚洲另类av| 国产精品伊人| 欧美aa一级| 国产欧美日韩| 久久精品欧美一区| 日本少妇一区二区| 国产盗摄——sm在线视频| 亚洲一区国产一区| 日韩精品网站| 亚洲精品88| 国产精一区二区| 亚洲免费中文| 精品一区二区三区四区五区| 久久精品国产99久久| 国产精品伊人| 亚洲免费专区| 国产成人精品一区二区三区免费| 日韩高清中文字幕一区二区| 最近国产精品视频| 伊人久久高清| 久久久成人网| 国产精品一级| 你懂的亚洲视频| 蜜臀av国产精品久久久久| 亚洲综合电影| 久久精选视频| 日韩精品社区| 国产精品日韩| 97精品久久| 中文字幕高清在线播放| 日本精品在线播放| 久久九九99| 婷婷综合六月| 精品九九在线| 久久国产日本精品| 亚洲欧美网站在线观看| 欧美日韩一区二区高清| 国产精品久久观看| 欧美91精品| 国产亚洲精品精品国产亚洲综合| 久久国产精品免费一区二区三区| 久久中文字幕一区二区三区|