<span id="mktg5"></span>

<i id="mktg5"><meter id="mktg5"></meter></i>

        <label id="mktg5"><meter id="mktg5"></meter></label>
        最新文章專題視頻專題問答1問答10問答100問答1000問答2000關鍵字專題1關鍵字專題50關鍵字專題500關鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關鍵字專題關鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
        問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
        當前位置: 首頁 - 科技 - 知識百科 - 正文

        深入理解javascript構造函數和原型對象_javascript技巧

        來源:懂視網 責編:小采 時間:2020-11-27 21:27:25
        文檔

        深入理解javascript構造函數和原型對象_javascript技巧

        深入理解javascript構造函數和原型對象_javascript技巧:常用的幾種對象創建模式 使用new關鍵字創建 最基礎的對象創建方式,無非就是和其他多數語言一樣說的一樣:沒對象,你new一個呀! var gf = new Object(); gf.name = tangwei; gf.bar = c++; gf.sayWhat = function() {
        推薦度:
        導讀深入理解javascript構造函數和原型對象_javascript技巧:常用的幾種對象創建模式 使用new關鍵字創建 最基礎的對象創建方式,無非就是和其他多數語言一樣說的一樣:沒對象,你new一個呀! var gf = new Object(); gf.name = tangwei; gf.bar = c++; gf.sayWhat = function() {
        常用的幾種對象創建模式

        使用new關鍵字創建
        最基礎的對象創建方式,無非就是和其他多數語言一樣說的一樣:沒對象,你new一個呀!

        使用字面量創建

        這樣似乎妥妥的了,但是宅寂的geek們豈能喜歡如此復雜和low土的定義變量的方式,作為一門腳本語言那應該有和其他兄弟們一樣的范兒,于是出現了對象字面量的定義方式:

        工廠模式

        實際上這是我們在實際中最常用的對象定義方式,但是我要有好多擁有相似屬性的對象(想想都讓人激動。。)怎么辦呢?那要是一個個的定義,就會產生大量的代碼,何不建個工廠,批量的生產出我們的對象呢,于是,javascript世界中第一個充氣娃。。不,“工廠模式”誕生了!

        構造函數

        工廠模式解決了多個相似對象的創建問題,但是問題又來了,這些對象都是Object整出來的,怎么區分它們的對象具體類型呢?這時候我們就需要切換到另一種模式了,構造函數模式:

        這里我們使用一個大寫字母開頭的構造函數替代了上例中的createGf,注意按照約定構造函數的首字母要大寫。在這里我們創建一個新對象,然后將構造函數的作用域賦給新對象,調用構造函數中的方法。
        上面的方式似乎沒什么不妥,但是我們可以發現,兩個實例中調用的構造函數中的sayWhat方法不是同一個Function實例:

        調用同一個方法,卻聲明了不同的實例,實在浪費資源。我們可以優化一下將sayWhat函數放到構造函數外面聲明:

        這樣解決了,多個實例多次定義同一個方法實例的問題,但是新問題又來了,我們定義的sayWhat是一個全局作用域的方法,但這個方法其實是沒法直接調用的,這就有點矛盾了。如何更優雅的定義一個具備一定封裝性的對象呢?我們來看一下javascript原型對象模式。

        原型對象模式

        理解原型對象
        當我們創建一個函數時,該函數就會具備一個prototype屬性,這個屬性指向通過構造函數創建的那個函數的原型對象。通俗點講原型對象就是內存中為其他對象提供共享屬性和方法的對象。

        在原型模式中,不必再構造函數中定義實例屬性,可以將屬性信息直接賦予原型對象:

        和構造函數不同的是這里新對象的屬性和方法是所有實例都可以共享的,換句話說gf1和gf2訪問的是同一份屬性和方法。原型對象中除了我們賦予的屬性外,還有一些內置的屬性,所有原型對象都具備一個constructor屬性,這個屬性是一個指向包含prototype屬性函數的一個指針(敢不敢再繞點!)。通過一幅圖我們來清楚的理一下這個繞口的流程:

        所有的對象都有一個原型對象(prototype),原型對象中有一個constructor屬性指向包含prototype屬性的函數,Gf的實例gf1和gf2都包含一個內部屬性指向原型對象(在firefox瀏覽器中表現為私有屬性proto),當我們訪問一個對象中的屬性時,首先會詢問實例對象中有沒有該屬性,如果沒有則繼續查找原型對象。

        使用原型對象
        在前面的示例中,我們注意到在為原型對象添加屬性時,需要每個都增加Gf.prototype,這個工作很重復,在上面對象的創建模式中,我們知道可以通過字面量的形式創建一個對象,這里我們也可以改進一下:

        這里有一個地方需要特別注意下,constructor屬性不再指向對象Gf,因為每定義一個函數,就會同時為其創建一個prototype對象,這個對象也會自動獲取一個新的constructor屬性,這個地方我們使用Gf.prototype本質上覆寫了原有的prototype對象,因此constructor也變成了新對象的constructor屬性,不再指向Gf,而是Object:

        一般情況下,這個微妙的改變是不會對我們造成影響的,但如果你對constructor有特殊的需求,我們也可以顯式的指定下Gf.prototype的constructor屬性:

        通過對原型對象模式的初步了解,我們發現所有的實例對象都共享相同的屬性,這是原型模式的基本特點,但往往對于開發者來說這是把“雙刃劍”,在實際開發中,我們希望的實例應該是具備自己的屬性,這也是在實際開發中很少有人單獨使用原型模式的主要原因。

        構造函數和原型組合模式

        在實際開發中,我們可以使用構造函數來定義對象的屬性,使用原型來定義共享的屬性和方法,這樣我們就可以傳遞不同的參數來創建出不同的對象,同時又擁有了共享的方法和屬性。

        在這個例子中,我們再構造函數中定義了對象各自的屬性值,在原型對象中定義了constructor屬性和sayWhat函數,這樣gf1和gf2屬性之間就不會產生影響了。這種模式也是實際開發中最常用的對象定義方式,包括很多js庫(bootstrap等)默認的采用的模式。

        聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

        文檔

        深入理解javascript構造函數和原型對象_javascript技巧

        深入理解javascript構造函數和原型對象_javascript技巧:常用的幾種對象創建模式 使用new關鍵字創建 最基礎的對象創建方式,無非就是和其他多數語言一樣說的一樣:沒對象,你new一個呀! var gf = new Object(); gf.name = tangwei; gf.bar = c++; gf.sayWhat = function() {
        推薦度:
        標簽: 技巧 js 對象
        • 熱門焦點

        最新推薦

        猜你喜歡

        熱門推薦

        專題
        Top
        主站蜘蛛池模板: 巨胸喷奶水www永久免费| 亚洲成a∧人片在线观看无码| 一级特黄色毛片免费看| 在线免费观看a级片| 亚洲精品无码人妻无码| 国产一卡2卡3卡4卡2021免费观看| 亚洲精品国产专区91在线| 57pao一国产成视频永久免费| 亚洲三级电影网站| 免费观看无遮挡www的小视频| 亚洲欧洲精品国产区| 国内精自视频品线六区免费| 亚洲国产综合第一精品小说| 91嫩草国产在线观看免费| 狠狠色香婷婷久久亚洲精品| 卡1卡2卡3卡4卡5免费视频| 特级毛片全部免费播放| 你是我的城池营垒免费看 | 777爽死你无码免费看一二区| 亚洲无限乱码一二三四区| 成人女人A级毛片免费软件| 精品亚洲456在线播放| 免费萌白酱国产一区二区| 一级特黄录像免费播放肥| 久久久久久久综合日本亚洲| 在线美女免费观看网站h| 久久久久se色偷偷亚洲精品av| 日韩免费观看一级毛片看看| 羞羞视频在线观看免费| 久久亚洲免费视频| 精品国产免费一区二区| CAOPORM国产精品视频免费| 青青草原精品国产亚洲av| 成人毛片免费视频| 2022国内精品免费福利视频| 亚洲欧洲春色校园另类小说| 国产国产人免费视频成69大陆| 91在线免费视频| 亚洲色欲色欱wwW在线| 伊人婷婷综合缴情亚洲五月| 97热久久免费频精品99|