欧美一区二区三区老妇人-欧美做爰猛烈大尺度电-99久久夜色精品国产亚洲a-亚洲福利视频一区二区

JSBase64編碼解碼的示例分析-創(chuàng)新互聯(lián)

這篇文章主要介紹JS Base64編碼解碼的示例分析,文中介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們一定要看完!

成都創(chuàng)新互聯(lián)公司是一家專(zhuān)注于成都網(wǎng)站設(shè)計(jì)、成都網(wǎng)站制作與策劃設(shè)計(jì),樂(lè)昌網(wǎng)站建設(shè)哪家好?成都創(chuàng)新互聯(lián)公司做網(wǎng)站,專(zhuān)注于網(wǎng)站建設(shè)十多年,網(wǎng)設(shè)計(jì)領(lǐng)域的專(zhuān)業(yè)建站公司;建站業(yè)務(wù)涵蓋:樂(lè)昌等地區(qū)。樂(lè)昌做網(wǎng)站價(jià)格咨詢(xún):18982081108

1. 基礎(chǔ)不牢,選型糟糕

糟糕的技術(shù)選型往往源自自身技術(shù)廣度不足。就在數(shù)月前,一個(gè)前端HTML字符信息轉(zhuǎn)Base64的需求,我是毫不猶豫去找了個(gè)開(kāi)源的base64.js。使用很簡(jiǎn)單,瀏覽器引入該JS文件,然后Base64編碼這樣:

JS Base64編碼解碼的示例分析

解碼就調(diào)用decode方法,如下:

JS Base64編碼解碼的示例分析

數(shù)據(jù)準(zhǔn)確,功能良好。當(dāng)時(shí)弄完還洋洋得意,以為是個(gè)完美的解決。結(jié)果,今天發(fā)現(xiàn),尼瑪原來(lái)瀏覽器很早就支持了JS Base64加密解密,而上面這種洋洋得意的做法完全就是瞎子點(diǎn)燈——白費(fèi)蠟!根本就不是一個(gè)好的技術(shù)選型。

由于技術(shù)廣度掌握不足,或者說(shuō)JS基礎(chǔ)掌握不牢,導(dǎo)致浪費(fèi)了大把時(shí)間去找Base64的JS語(yǔ)言庫(kù),學(xué)習(xí)其API用法,換來(lái)一個(gè)冗余完全不需要加載的JS,現(xiàn)在來(lái)看,真是個(gè)糟糕的技術(shù)選型。

2. 原生atob和btoa方法

實(shí)際上,從IE10+瀏覽器開(kāi)始,所有瀏覽器就原生提供了Base64編碼解碼方法,不僅可以用于瀏覽器環(huán)境,Service Worker環(huán)境也可以使用。

方法名就是atob和btoa,具體語(yǔ)法如下:

1)Base64解碼

語(yǔ)法為(瀏覽器中):

var decodedData = window.atob(encodedData);

或者(瀏覽器或js Worker線程中):

var decodedData = self.atob(encodedData);

例如:

window.atob('emhhbmd4aW54dQ==');

// 返回:'zhangxinxu'

atob這個(gè)方法名稱(chēng)乍一看,很奇怪,不知道這個(gè)單詞什么意思。我們可以理解為 A to B,也就是從A到B。這里的B指的就是Base64嗎?哈哈哈,恭喜你!猜錯(cuò)了!A指的才是Base64,反的,B才是普通字符,普通意思就是low,俗稱(chēng)low B。所以我們這么記憶,Low B,Low B,B表示很Low的普通字符,A才是Base64,和首字母對(duì)應(yīng)關(guān)系是反的。

因此,atob表示Base64字符to普通字符,也就是Base64解碼。

2)Base64編碼

語(yǔ)法為(瀏覽器中):

var encodedData = window.btoa(stringToEncode);

或者(瀏覽器或js Worker線程中):

var encodedData = self.btoa(stringToEncode);

例如:

window.btoa('zhangxinxu');

// 返回:'emhhbmd4aW54dQ=='

btoa這個(gè)方法名稱(chēng)乍一看,很奇怪,不知道這個(gè)單詞什么意思。我們可以理解為 B to A,也就是從B到A。那B指什么,A指什么呢?和atob方法一樣,B指的是low B普通字符串,A指的是Base64字符。

因此,btoa方法表示low B普通字符to Base64字符,也就是Base64編碼。

3. IE8/IE9的polyfill

當(dāng)下,仍有不少PC項(xiàng)目還需要兼容IE9,所以,我們可以專(zhuān)門(mén)針對(duì)這些瀏覽器再引入一段ployfill腳本或者一個(gè)JS文件即可。

實(shí)際使用,我們可以借助IE條件注釋無(wú)縫對(duì)接。也就是HTML中嵌入下面一段代碼:

JS Base64編碼解碼的示例分析

[if IE]表示所有IE瀏覽器,由于IE10+瀏覽器已經(jīng)放棄了著名的IE條件注釋的支持,Chrome等瀏覽器本身就不支持這個(gè)IE私有語(yǔ)法,因此,很天然的,上面一段script引入只在IE9-瀏覽器下有效。而我們本來(lái)就希望只IE8,IE9瀏覽器引入ployfill,于是正好完美銜接上。

也就是原生支持atob和btoa方法的瀏覽器認(rèn)為就是一段無(wú)需關(guān)心的HTML注釋?zhuān)恢С謅tob和btoa的IE9及其以下瀏覽器則會(huì)加載我們的base64-polyfill.js,使瀏覽器也支持window.btoa和window.atob這個(gè)語(yǔ)法。

以上是“JS Base64編碼解碼的示例分析”這篇文章的所有內(nèi)容,感謝各位的閱讀!希望分享的內(nèi)容對(duì)大家有幫助,更多相關(guān)知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)成都網(wǎng)站設(shè)計(jì)公司行業(yè)資訊頻道!

另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務(wù)器15元起步,三天無(wú)理由+7*72小時(shí)售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國(guó)服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡(jiǎn)單易用、服務(wù)可用性高、性?xún)r(jià)比高”等特點(diǎn)與優(yōu)勢(shì),專(zhuān)為企業(yè)上云打造定制,能夠滿(mǎn)足用戶(hù)豐富、多元化的應(yīng)用場(chǎng)景需求。

網(wǎng)頁(yè)標(biāo)題:JSBase64編碼解碼的示例分析-創(chuàng)新互聯(lián)
標(biāo)題來(lái)源:http://chinadenli.net/article12/dhghgc.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供外貿(mào)網(wǎng)站建設(shè)、網(wǎng)站導(dǎo)航、品牌網(wǎng)站建設(shè)、網(wǎng)站改版、微信公眾號(hào)、全網(wǎng)營(yíng)銷(xiāo)推廣

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶(hù)投稿、用戶(hù)轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話(huà):028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

網(wǎng)站托管運(yùn)營(yíng)