Base64編碼&&模擬實現(xiàn)js的bind方法

Q:Base64是一種基于64個可打印字符來表示二進制數(shù)據(jù)的一種方法

因為網(wǎng)絡上傳輸?shù)淖址蝗强纱蛴∽址热缍M制文件顾犹,圖片等庭砍,Base64就是為了解決此問題
Base64在URL,Cookie,網(wǎng)頁傳輸二進制文件中等到應用
字符有 A-Z,a-z,0-9,+,/共64個可打印字符
4個Base64(3bit)字符串可以表示3個標準的ascll字符(8bit)
不足三個字符的話拾并,直接最后添加"="揍堰,"=="填充符
轉(zhuǎn)換步驟

  • 將轉(zhuǎn)換的字符串每三個字節(jié)分為一組鹏浅,每個字節(jié)占8bit嗅义,共有24個二進制位
  • 將上面的24個二進制位每6個一組,分四組
  • 在每組前面添加兩個0隐砸,6個bit變?yōu)?個bit之碗,共4個字節(jié)
  • 根據(jù)Base64編碼表獲得對應的值
    Base64主要用在傳輸,存儲季希,表示二進制領(lǐng)域褪那,不能算的上加密,只是無法直接看到明文
    base64編碼圖片 優(yōu)點
  • 減少http請求
  • 可對數(shù)據(jù)簡單加密
  • 沒有跨域問題式塌,無需考慮圖片緩存
Q:能否模擬實現(xiàn)JS的bind方法

1.bind是Function原型鏈中的一個方法博敬,修改this的執(zhí)行,綁定第一個參數(shù)峰尝,返回值是一個新的函數(shù)
2.bind返回的函數(shù)可以通過new 調(diào)用偏窝,這時提供的this指向new生成的全新對象

var obj = {
  name: 'mingge'
}
function fn(a,b){
  console.log(this.name)
  console.log(a+b)
}
var bindfn = fn.bind(obj,3)
bindfn(5) // 'mingge'  8

// 實現(xiàn)代碼

Function.prototype.bind = Function.prototype.bind || function(targetObj){
  if(typeof this !== 'function'){throw new TypeError('must be function')}
  var self = this
  var args = [].slice.call(arguments,1)
  // 返回一個新的函數(shù)
  // 實現(xiàn) bound 可以使用new 調(diào)用
  var bound =  function(){
    var newArgs = [].slice.call(arguments)
    var finalArgs = args.concat(newArgs)
    if(this instanceof bound){
        if(self.prototype){
          bound.prototype = Object.create(self.prototype)
        }
        // 如果返回的不是引用類型的值,就返回this
        // 生成的新對象會綁定到函數(shù)調(diào)用的this上
        var result = self.apply(this, finalArgs)
        var isObject = typeof result === 'object' && result !== null
        var isFunction = typeof result === 'function'
        if(isObject || ifFunction) {return result}
        return this       
    }
   
    return self.apply(targetObj, finalArgs )
  }
  return bound
}

Q:能否模擬實現(xiàn)JS的new操作符

new 做了什么

  • 創(chuàng)建一個全新的對象
  • 這個對象會被執(zhí)行[[prototype]]鏈接,指向原型對象
  • 生成的新對象會綁定到構(gòu)造函數(shù)內(nèi)部的this
  • 通過new 創(chuàng)建的每個對象將最終被[[prototype]]鏈接到這個函數(shù)的prototype對象上
  • 如果函數(shù)沒有返回對象類型object祭往,那么new表達式中的函數(shù)調(diào)用會自動返回這個新的對象
/**
*模擬實現(xiàn)new操作符
*@param {Function} ctor [構(gòu)造函數(shù)]
*@return{引用類型}*/
function new(ctor) {
 if(typeof ctor !== 'function'){
   throw new Error('must be a function')
 }
 // 實現(xiàn)ES6 new.target 的指向構(gòu)造函數(shù)
 new.target = ctor
 //1.創(chuàng)建一個新對象
 //2.并且執(zhí)行[[prototype]]鏈接
 //4.通過new創(chuàng)建的每個對象將最終被[[prototype]]鏈接到這個函數(shù)的原型對象上
 var newObj = Object.create(ctor.prototype)
 var args = [].slice.call(arguments,1)//去掉ctor的全部參數(shù)
 // 3.將生成的新對象實例會綁定到構(gòu)造函數(shù)內(nèi)部的this
 // 并獲取到返回結(jié)果
 var result = ctor.apply(newObj, args)
 var isObject = typeof result === 'object' && result !== null
 var isFunction = typeof result === 'function'
 if(isObject || isFunction){
     return result
 }
 return newObj
}

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末伦意,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子硼补,更是在濱河造成了極大的恐慌驮肉,老刑警劉巖,帶你破解...
    沈念sama閱讀 217,907評論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件已骇,死亡現(xiàn)場離奇詭異离钝,居然都是意外死亡,警方通過查閱死者的電腦和手機疾捍,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,987評論 3 395
  • 文/潘曉璐 我一進店門奈辰,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人乱豆,你說我怎么就攤上這事奖恰。” “怎么了宛裕?”我有些...
    開封第一講書人閱讀 164,298評論 0 354
  • 文/不壞的土叔 我叫張陵瑟啃,是天一觀的道長。 經(jīng)常有香客問我揩尸,道長蛹屿,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,586評論 1 293
  • 正文 為了忘掉前任岩榆,我火速辦了婚禮错负,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘勇边。我一直安慰自己犹撒,他們只是感情好,可當我...
    茶點故事閱讀 67,633評論 6 392
  • 文/花漫 我一把揭開白布粒褒。 她就那樣靜靜地躺著识颊,像睡著了一般。 火紅的嫁衣襯著肌膚如雪奕坟。 梳的紋絲不亂的頭發(fā)上祥款,一...
    開封第一講書人閱讀 51,488評論 1 302
  • 那天,我揣著相機與錄音月杉,去河邊找鬼刃跛。 笑死,一個胖子當著我的面吹牛苛萎,可吹牛的內(nèi)容都是我干的桨昙。 我是一名探鬼主播跌帐,決...
    沈念sama閱讀 40,275評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼绊率!你這毒婦竟也來了谨敛?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,176評論 0 276
  • 序言:老撾萬榮一對情侶失蹤滤否,失蹤者是張志新(化名)和其女友劉穎脸狸,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體藐俺,經(jīng)...
    沈念sama閱讀 45,619評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡炊甲,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,819評論 3 336
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了欲芹。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片卿啡。...
    茶點故事閱讀 39,932評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖菱父,靈堂內(nèi)的尸體忽然破棺而出颈娜,到底是詐尸還是另有隱情,我是刑警寧澤浙宜,帶...
    沈念sama閱讀 35,655評論 5 346
  • 正文 年R本政府宣布官辽,位于F島的核電站,受9級特大地震影響粟瞬,放射性物質(zhì)發(fā)生泄漏同仆。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,265評論 3 329
  • 文/蒙蒙 一裙品、第九天 我趴在偏房一處隱蔽的房頂上張望俗批。 院中可真熱鬧,春花似錦市怎、人聲如沸岁忘。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,871評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽臭觉。三九已至昆雀,卻和暖如春辱志,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背狞膘。 一陣腳步聲響...
    開封第一講書人閱讀 32,994評論 1 269
  • 我被黑心中介騙來泰國打工揩懒, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人挽封。 一個月前我還...
    沈念sama閱讀 48,095評論 3 370
  • 正文 我出身青樓已球,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子智亮,可洞房花燭夜當晚...
    茶點故事閱讀 44,884評論 2 354

推薦閱讀更多精彩內(nèi)容

  • 第2章 基本語法 2.1 概述 基本句法和變量 語句 JavaScript程序的執(zhí)行單位為行(line)忆某,也就是一...
    悟名先生閱讀 4,149評論 0 13
  • 概要 64學時 3.5學分 章節(jié)安排 電子商務網(wǎng)站概況 HTML5+CSS3 JavaScript Node 電子...
    阿啊阿吖丁閱讀 9,197評論 0 3
  • 第3章 基本概念 3.1 語法 3.2 關(guān)鍵字和保留字 3.3 變量 3.4 數(shù)據(jù)類型 5種簡單數(shù)據(jù)類型:Unde...
    RickCole閱讀 5,126評論 0 21
  • 湖州師范學院文學院實踐隊:“相偕雨苗,以愛迭橋” 將詩詞歌賦帶進鐵路新村 2018年7月9日阔蛉,湖州師范學院文學院...
    青玉案永遇樂閱讀 330評論 0 0
  • 一時語塞弃舒,不知從何說起。 從前有個鳥地方状原,一個住著許多白癡的地方聋呢。 它們編織夢,他們制造曲奇卻以謊言調(diào)味颠区。 從前有...
    Clown_and_smile閱讀 371評論 1 0