亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

了解Javascript中函數作為對象的魅力

2019-11-19 11:18:52
字體:
來源:轉載
供稿:網友

前言

Javascript賦予了函數非常多的特性,其中最重要的特性之一就是將函數作為第一型的對象。那就意味著在javascript中函數可以有屬性,可以有方法, 可以享有所有對象所擁有的特性。并且最重要的,她還可以直接被調用

我們簡單的試驗一下就可以發現

// 簡單實驗 函數作為對象的存在let fn = function () {}fn.prop = 'fnProp'console.log(fn.prop) // fnProp

為函數添加屬性的這個特性我覺的大家在平時的開發中基本沒什么嘗試或者是使用過,但是在一些JS庫或者是事件回掉管理中都能發揮出很大的用處。下面一起來看幾個例子。

函數緩存

在某有一些的情況下我們可以要存儲一組相關但是相互又獨立的函數。這個需求看起來很easy,實現起來也不復雜。最顯而易見的做法是使用一個數組來保存所有的函數,
這樣不是不可以,但是顯然這種做法不是最好的。下面通過為函數屬性我們呢來實現這個我們的目的

// 1:函數緩存示例let store = {nextId: 1, // idcache: {}, // 緩存add (fn) {// 如果函數中沒有id屬性那么就緩存if (!fn.id) {console.log(`begin add func ${fn.name}`)fn.id = store.nextId ++// 設置完緩存之后返回truereturn !!(store.cache[fn.id] = fn)} else {console.log(`${fn.name} is already in cache`)}}}function storeCache() {}store.add(storeCache) // begin add func storeCachestore.add(storeCache) // storeCache is already in cache

上面的這一段代碼邏輯清晰,store對象用來管理我們的緩存,cache屬性用來存儲函數,nextId屬性用來保存當前的緩存Id,add()方法用來設置存儲,先來判斷當前函數是否已經在緩存中然后再去設置緩存,這樣就能限制函數的重復添加,最后返回true。

!!構造是一種可以將任意Javascript表達式轉化為其等效布爾值的簡單方式。

緩存記憶函數

這種函數可以記住之前已經計算過的結果,避免了不必要的計算,這顯然是能夠提升代碼性能的。

在舉例之前我們先來看看這種方式的優缺點

優點

  • 緩存了之前的結果,最終用戶享有性能優勢
  • 實際上是發生在幕后,操作無感

缺點

  • 內存的犧牲這是肯定的
  • 打破了存粹性(一個函數或者方法應該只做好一件事)
  • 如果方法中有算法,那么很難測量這個算法的性能

了解了優缺點我們來看一個簡單的計算素數的例子(不是很嚴謹)

// 2: 緩存記憶函數function isPrime (value) {if (!isPrime.anwers) isPrime.anwers = {}// 先從緩存里面取if (isPrime.anwers[value] != null ) {return isPrime.anwers[value]}// 開始進行判斷和計算let prime = value != 1for (let index = 2; index < value; index++) {if (value % index == 0) {prime = falsebreak;} }// 保存計算出來的值return isPrime.anwers[value] = prime}console.log(isPrime(5))console.log(`從函數記憶中直接讀取${isPrime.anwers[5]}`)

這里呢 好處是特別明顯的我們再次的取用isPrime.anwers[5]的時候不需要經過任何的計算,但是大型的計算要主要內存的使用

緩存記憶DOM元素

通過元素的標簽查詢DOM的操作的的代價是昂貴的,各位前端大佬肯定都很清楚。我們下面使用緩存記憶的方式來進行這個操作

// 3:緩存記憶DOM元素function getElements (name) {if (!getElements.cache) getElements.cache = {}return getElements.cache[name] = getElements.cache[name] || document.getElementsByTagName(name);}console.log(getElements('div')) // HTMLCollectionconsole.log(getElements.cache['div']) // HTMLCollection

這個函數和上面的緩存使用的同一個手法,而且這簡單的4句代碼能為我們的性能帶來大幅度的提升。這也算是一種超能力吧。函數的很多特性都和其上下文有關,接下來我們研究一個和上下文又換的例子。

偽造數組方法(上下文相關)

在一些情況下我們想創建一個包含一組數據的對象,但是這個數據包含很多的狀態,比如和集合項有關的元數據那么我們用數組來存就不太合適了。那么這里我們就用對象的方式來假扮數組。通過改變上下文來完成一些“不法的行為”

// 4:偽造數組方法// <input type="button" id="add" >// <input type="button" id="remove" >let elems = {length: 0, //為了保存個數add (elem) {Array.prototype.push.call(this, elem)},gather (id) {this.add(document.getElementById(id))}}elems.gather('add')elems.gather('remove')console.log(elems[0]); // <input type="button" id="add" >console.log(elems[1]); // <input type="button" id="remove" >console.log(elems.length); // 2console.log(elems);/**0: input#add1: input#removeadd: ƒ add(elem)gather: ƒ gather(id)length: 2*/

在我還對JS懵懵懂懂的時候看到這樣的操作被秀了一臉,簡直是刺激了我幼小的心靈。

我們在add函數中實現了把元素添加到了集合中,而且Array又正好提供push方法, 不用白不用。這種操作也是直白的展示了函數上下文的超強特性。

總結

Javascript強大的靈活性, 也帶來更多的可能性。 路漫漫其修遠兮,吾將上下而求索。

代碼地址

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持武林網。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美xxxx18性欧美| 国产中文欧美精品| 亚洲天堂av在线免费| 国产欧美最新羞羞视频在线观看| 视频在线观看一区二区| 国产成人精品免费视频| 欧美在线影院在线视频| 久久91精品国产| 国产精品久久久久久久久免费看| 国产精品美乳在线观看| 国产精品免费在线免费| 亚洲人成五月天| 成人久久一区二区三区| 亚洲午夜精品视频| 国产视频在线一区二区| 尤物九九久久国产精品的分类| 久久久久久久亚洲精品| 国产91对白在线播放| 国产精品精品视频| 欧美日韩国产色视频| 中文字幕自拍vr一区二区三区| 亚洲欧洲免费视频| 久久影院模特热| 国产suv精品一区二区三区88区| 国产福利视频一区二区| 欧洲s码亚洲m码精品一区| 大荫蒂欧美视频另类xxxx| 黄色成人av网| 欧美性猛交xxxx乱大交极品| 欧美日韩亚洲天堂| 97高清免费视频| 欧美性20hd另类| 国产精品欧美激情在线播放| 亚洲最大成人免费视频| 久久久精品在线观看| 91黑丝高跟在线| 日韩免费在线电影| 国产精品高精视频免费| 精品在线观看国产| 日韩美女在线观看| 欧美激情综合亚洲一二区| 欧美日韩国产成人在线| 久久精品人人爽| 奇米成人av国产一区二区三区| 国产精品久久久久7777婷婷| 国产精品毛片a∨一区二区三区|国| 91午夜在线播放| 国产69精品久久久久9999| 国产精品一区二区三区成人| 91在线免费视频| 亚洲欧洲日本专区| 久久久久久久久久久91| 日韩女优人人人人射在线视频| 欧美午夜女人视频在线| 国产精品www网站| 亚洲欧美制服中文字幕| 色偷偷亚洲男人天堂| 国产成人久久久| 亚洲桃花岛网站| 91系列在线观看| 日韩av在线资源| 日韩一区二区久久久| 97视频在线观看网址| 操91在线视频| 欧美成人精品在线播放| 精品一区二区三区四区| 久久国产精品亚洲| 欧美极品第一页| 亚洲国产一区二区三区四区| 中文字幕在线观看日韩| 欧美性猛交xxxx富婆| 亚洲第一页中文字幕| 国产精品扒开腿做爽爽爽的视频| 高清视频欧美一级| 日韩专区中文字幕| 亚洲一区免费网站| 国产日韩欧美成人| 欧美激情乱人伦| 国外成人免费在线播放| 日韩在线观看电影| 亚洲欧美另类在线观看| 国产精品第2页| 国产精品高潮呻吟视频| 欧美午夜无遮挡| 亚洲国产小视频| 欧美在线性视频| 久久噜噜噜精品国产亚洲综合| 98视频在线噜噜噜国产| 91中文字幕一区| 国产精品美女无圣光视频| 国产精品视频免费观看www| 懂色av影视一区二区三区| 亚洲欧美另类人妖| 久久精品国产欧美激情| 亚洲国产精品网站| 亚洲黄色成人网| 97超级碰碰碰| 国产精品白嫩初高中害羞小美女| 国产欧美日韩丝袜精品一区| 97超碰蝌蚪网人人做人人爽| 国产小视频91| 成人激情视频网| 青青在线视频一区二区三区| 亚洲伊人一本大道中文字幕| 国产精品流白浆视频| 精品成人久久av| 国产精品91久久久久久| 日韩天堂在线视频| 97国产精品免费视频| 久久久久亚洲精品成人网小说| 成人免费看片视频| 国产在线精品成人一区二区三区| 国产欧美一区二区三区久久人妖| 日韩精品一区二区三区第95| 中文字幕亚洲一区二区三区| 91成人免费观看网站| 日韩成人高清在线| 午夜精品久久久99热福利| 亚洲日韩欧美视频| www.欧美精品一二三区| 亚洲国产日韩欧美综合久久| 欧美大肥婆大肥bbbbb| 俺去啦;欧美日韩| 欧美日韩国产一中文字不卡| 国产精品永久免费在线| 国产午夜精品视频免费不卡69堂| 国产欧美一区二区三区在线| 8050国产精品久久久久久| 欧美精品精品精品精品免费| 成人在线精品视频| 亚洲在线视频观看| 亚洲一区二区免费在线| 国产美女搞久久| 日韩亚洲国产中文字幕| 亚洲精品一区在线观看香蕉| 欧美专区国产专区| 亚洲最新av在线网站| 亚洲第一精品久久忘忧草社区| 91精品在线播放| 成人黄色在线免费| 久久亚洲精品国产亚洲老地址| 美女久久久久久久| 国产精品久久久久久网站| 欧美在线影院在线视频| 91国偷自产一区二区三区的观看方式| 5566日本婷婷色中文字幕97| 裸体女人亚洲精品一区| 青青在线视频一区二区三区| 欧美成人剧情片在线观看| 精品久久久久久中文字幕一区奶水| 国产精品久久久91| 欧美亚洲另类制服自拍| 亚洲一区二区日本| 98精品国产高清在线xxxx天堂| 欧美超级乱淫片喷水| 亚洲精品乱码久久久久久按摩观| 成人在线精品视频| 中文字幕日韩精品在线观看| 欧美黄色成人网| 68精品国产免费久久久久久婷婷| 91国语精品自产拍在线观看性色| 亚洲精品日韩激情在线电影| 北条麻妃在线一区二区| 欧美激情亚洲另类|