电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

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

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

瀏覽:100日期: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
主站蜘蛛池模板: 上海璟文空运首页_一级航空货运代理公司_机场快递当日达 | 大型多片锯,圆木多片锯,方木多片锯,板材多片锯-祥富机械有限公司 | 四川职高信息网-初高中、大专、职业技术学校招生信息网 | 浙江皓格药业有限公司| 郑州水质检测中心_井水检测_河南废气检测_河南中环嘉创检测 | 儿童乐园|游乐场|淘气堡招商加盟|室内儿童游乐园配套设备|生产厂家|开心哈乐儿童乐园 | 品牌策划-品牌设计-济南之式传媒广告有限公司官网-提供品牌整合丨影视创意丨公关活动丨数字营销丨自媒体运营丨数字营销 | 老房子翻新装修,旧房墙面翻新,房屋防水补漏,厨房卫生间改造,室内装潢装修公司 - 一修房屋快修官网 | 考勤系统_考勤管理系统_网络考勤软件_政企|集团|工厂复杂考勤工时统计排班管理系统_天时考勤 | 美国PARKER齿轮泵,美国PARKER柱塞泵,美国PARKER叶片泵,美国PARKER电磁阀,美国PARKER比例阀-上海维特锐实业发展有限公司二部 | 中细软知识产权_专业知识产权解决方案提供商 | 行星齿轮减速机,减速机厂家,山东减速机-淄博兴江机械制造 | 电动葫芦-河北悍象起重机械有限公司 | Boden齿轮油泵-ketai齿轮泵-yuken油研-无锡新立液压有限公司 | 桂林腻子粉_内墙外墙抗裂砂浆腻子粉推荐广西鑫达涂料厂家供应 | 纯化水设备-纯水设备-超纯水设备-[大鹏水处理]纯水设备一站式服务商-东莞市大鹏水处理科技有限公司 | arch电源_SINPRO_开关电源_模块电源_医疗电源-东佑源 | 锂电混合机-新能源混合机-正极材料混料机-高镍,三元材料混料机-负极,包覆混合机-贝尔专业混合混料搅拌机械系统设备厂家 | 衬塑设备,衬四氟设备,衬氟设备-淄博鲲鹏防腐设备有限公司 | 一体化预制泵站-一体化提升泵站-一体化泵站厂家-山东康威环保 | 红外光谱仪维修_二手红外光谱仪_红外压片机_红外附件-天津博精仪器 | 工业机械三维动画制作 环保设备原理三维演示动画 自动化装配产线三维动画制作公司-南京燃动数字 聚合氯化铝_喷雾聚氯化铝_聚合氯化铝铁厂家_郑州亿升化工有限公司 | 警用|治安|保安|不锈钢岗亭-售货亭价格-垃圾分类亭-移动厕所厂家-苏州灿宇建材 | 众品地板网-地板品牌招商_地板装修设计_地板门户的首选网络媒体。 | 防爆正压柜厂家_防爆配电箱_防爆控制箱_防爆空调_-盛通防爆 | 卧涛科技有限公司科技项目申报公司|高新技术企业申报|专利申请 | 胃口福饺子加盟官网_新鲜现包饺子云吞加盟 - 【胃口福唯一官网】 | 北京模型公司-军事模型-工业模型制作-北京百艺模型沙盘公司 | 网架支座@球铰支座@钢结构支座@成品支座厂家@万向滑动支座_桥兴工程橡胶有限公司 | 橡胶弹簧|复合弹簧|橡胶球|振动筛配件-新乡市永鑫橡胶厂 | China plate rolling machine manufacturer,cone rolling machine-Saint Fighter | YJLV22铝芯铠装电缆-MYPTJ矿用高压橡套电缆-天津市电缆总厂 | 南京雕塑制作厂家-不锈钢雕塑制作-玻璃钢雕塑制作-先登雕塑厂 | 电镀电源整流器_高频电解电源_单脉双脉冲电源 - 东阳市旭东电子科技 | 激光内雕_led玻璃_发光玻璃_内雕玻璃_导光玻璃-石家庄明晨三维科技有限公司 激光内雕-内雕玻璃-发光玻璃 | 打造全球沸石生态圈 - 国投盛世| 首页 - 张店继勇软件开发工作室 兰州UPS电源,兰州山特UPS-兰州万胜商贸 | 布袋除尘器|除尘器设备|除尘布袋|除尘设备_诺和环保设备 | 裹包机|裹膜机|缠膜机|绕膜机-上海晏陵智能设备有限公司 | 威廉希尔WilliamHill·足球(中国)体育官方网站 | 好笔杆子网 - 公文写作学习交流分享平台|