原型prototype

来源:http://www.cnblogs.com/ghlucky/archive/2016/07/31/5724097.html
-Advertisement-
Play Games

JS對象的比較 由於JS是解釋執行的語言,那麼代碼中出現函數與對象如果重覆執行,會創建多個副本 在開發中會引入各種框架和庫,自定義的成員越多,出現命名衝突的幾率越大 在開發中會有多個構造函數,,每一個構造函數有很多方法,就會變得不容易維護 原型相關的概念 關於面向對象的概念 類 class 在js中 ...


JS對象的比較

由於JS是解釋執行的語言,那麼代碼中出現函數與對象如果重覆執行,會創建多個副本

  1. 創建一個Person構造函數,要求有name,age,gender,sayHello
  2. 代碼如下:
     function Person(name,age,gender){
         this.name=name;
         this.age=age;
         this.gender=gender;
         this.sayHello=function(){};
     }
    
  3. 這種構造函數會影響性能,容易造成多個對象有多個對象副本,應該將方法單獨抽取出來,讓所有的對象共用該方法. 代碼如下:
     function sayHello(){};
     function Person(name,age,gender){
             this.name=name;
             this.age=age;
             this.gender=gender;
             this.sayHello=sayHello;
         }
    
  4. 可以考慮將方法全部放到外面,但是有安全隱患
    • 在開發中會引入各種框架和庫,自定義的成員越多,出現命名衝突的幾率越大
    • 在開發中會有多個構造函數,,每一個構造函數有很多方法,就會變得不容易維護
  5. 解決辦法是外面的函數不占用名字,而且在構造函數旗下就可以了
  6. 每一個構造函數在定義的時候,都會有一個神秘對象被創建出來
  7. 每一個由構造函數創建出來的實例對象都會預設的連接到該神秘對象上 代碼如下:
    function Person(name,age,gender){
                this.name=name;
                this.age=age;
                this.gender=gender;
            }
     Person.prototype.sayHello=function(){
            console.log( 'hello!' ) ;
     };
    var p1=new Person('張三',10,'male');
    p1.sayHello()
    var p2=new Person('張四',13,'male');
    p2.sayHello();
  1. 該神秘對象就是prototype,由構造函數創建出來的眾多對象共用的一個對象
  2. 只需要將共用的東西,重覆會多占用記憶體的東西放到構造函數.prototype中,那麼所有的對象都可以共用

原型相關的概念

  1. 關於面向對象的概念

    • 類 class 在js中就是構造函數
      • 在傳統的面向對象語言中,使用一個叫類的東西定義模版,然後使用模版創建對象
      • 在構造方法中也具有類似的功能,因此稱其為類
    • 實例與對象
      • 實例一般是指某一個構造函數創建出來的對象,我們稱這個對象為這個構造函數的實例
      • 實例就是一個對象,對象是一個泛稱
    • 鍵值對與屬性和方法
      • 在js中鍵值對的集合稱為對象
      • 如果值為數據(非函數),就稱該鍵值對為對象的屬性 property
      • 如果值為函數,就稱為對象的方法 method
    • 父類與子類
      • 傳統的面向語言中使用類來繼承,就有父類,子類的概念
      • 父類又稱為基類, 子類又稱為派生類
      • 在 js 中常常稱為父對象, 子對象. 基對象, 派生對象
  2. 原型相關的概念

    • 神秘對象針對構造函數稱為 "原型屬性"
      • 神秘對象就是構造函數的原型屬性
      • 簡稱原型
    • 神秘對象針對構造函數創建出來的對象稱為"原型對象"
      • 當訪問實例對象的屬性時或方法時,如果構造函數沒有,就到到對應的原型對象中去找
      • 簡稱原型
    • 對象繼承自其原型
      • 構造函數創建的對象 繼承自 構造函數的原型屬性
      • 構造函數創建的對象 繼承自 該對象的原型對象
      • 構造函數創建的對象與構造函數的原型屬性表示的是兩個不同的對象
        • 原型中的成員可以直接被實例對象所使用
        • 實例對象繼承自原型
        • 這樣的繼承就是 "原型繼承"
  3. 如何使用原型

    • 使用對象的動態特性
      • 構造函數.prototype.XXX = vvvv;
    • 直接替換
        Student.prototype = {
             sayHello: function () {},
             study: function () {}
         };

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 初探MVC Model:負責定義信息格式月信息訪問的界面,包括商業邏輯與信息驗證。 View:負責用戶界面相關呈現,包括輸入與輸出。 Controller:負責控制系統的運行流程、跟瀏覽器的交互、決定網頁操作的流程與動線、響應客戶端的各種要求、錯誤處理等等。 定義數據結構 負責與資料庫溝通 從資料庫 ...
  • 理解深拷貝和淺拷貝之前需要弄懂一些基礎概念,記憶體中存儲的變數類型分為值類型和引用類型。 1、值類型賦值的存儲特點, 將變數內的數據全部拷貝一份, 存儲給新的變數。 例如:var num = 123 ;var num1=num; 表示變數中存儲的數字是 123。然後將數據拷貝一份,就是將 123 拷貝 ...
  • SVG描邊動畫原理其實很簡單,主要利用以下兩個屬性 stroke-dasharray 製作虛線,使得黑白相間, stroke-dashoffset 使得虛線向開頭偏移,這裡的1500不精確,是我隨便取的,下文介紹通過JS獲取長度。 動畫就是減少虛線偏移,那麼實線就會慢慢漏出來了 JS獲取長度 var ...
  • SVG是什麼 SVG是什麼 SVG 指可伸縮矢量圖形 (Scalable Vector Graphics) SVG 用來定義WEB上使用的矢量圖 SVG 使用 XML 格式定義圖形 SVG 圖像在縮放時其圖形質量不會有所損失 SVG 是W3C推薦的 SVG 與諸如 DOM和 XSL 之類的W3C標準 ...
  • ES6新特性之 函數參數的預設值寫法 和 箭頭函數。 1、函數參數的預設值 ES5中不能直接為函數的參數指定預設值,只能通過以下的變通方式: 從上面的代碼可以看出存在一個問題,當傳入的參數為0或者false時,會直接取到後面的值,而不是傳入的這個參數值。 那怎麼解決呢?對於上圖的代碼,可以通過判斷是 ...
  • 一、前言 昨天我們瞭解了Js的很重要的一個概念叫做函數,函數就是對於冗餘和垃圾代碼的一種封裝機制。簡單的講就是為了能讓程式更好更快的執行我們將一些重覆性的代碼提取,封裝成一個有名字的小盒子,等到我們需要的時候我們可以直接將盒子拿出來使用。 二、引入 無論是在前端還是後臺語言中函數都是一個個成功程式的 ...
  • 在javascript中,this指代的對象時常會變化,這會造成程式,混亂,一般做法就是先將this保存在一個變數中,就不怕她變了,我們先看一個小例子 JQuery提供了proxy方法,它可以綁定代理一個對象,this變了,我不怕不怕啦,that當this,我不怕不怕不怕啦,proxy有了你出現,對 ...
  • 本人是一名.net程式員..... 你一個.net coder 看什麼jQuery 源碼啊? 原因嗎,很簡單。技多不壓身嗎(麻蛋,前端工作好高...羡慕)。 我一直都很喜歡JavaScript,廢話不多說了,直接切入正題。 最近看了好幾篇jQuery 源碼的文章,對於jQuery的無new構建 很是 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...