JavaScript之原型 Prototype

来源:https://www.cnblogs.com/wyuzm/archive/2018/12/07/10081639.html
-Advertisement-
Play Games

1、我們所創建的每一個函數,解析器都會向函數中添加一個屬性prototype。這個屬性對應著一個對象,這個對象就是我們所謂的原型對象。如果函索作為普通函數調用prototype沒有任何作用。 當函數以構造函數的形式調用時,它所創建的對象中都會有一個隱含的屬性 指向該構造函數的原型對象,我們可以通過_ ...


1、我們所創建的每一個函數,解析器都會向函數中添加一個屬性prototype。這個屬性對應著一個對象,這個對象就是我們所謂的原型對象。如果函索作為普通函數調用prototype沒有任何作用。

當函數以構造函數的形式調用時,它所創建的對象中都會有一個隱含的屬性

指向該構造函數的原型對象,我們可以通過__proto__來訪問屬性

原型對象就相當於一個公共的區域,所有同一個類的實例都可以訪問到這個原型對象,我們可以將對象中共有的內容,統一設置到原型對象中。

當我們訪問對象的一個屬性或方法時,它會先在對象自身中尋找,如果有則直接使用,如果沒有則會去原型對象中尋找,如果找到則直接使用

當我們創建構造函數時,可以將這些對象共有的屬性和方法,統一添加到構造函數的原型對象中

這樣不用分別為每一個對象添加,也不會影響到全局作用域,就可以使每個對象都具有這些屬性和方法了

 1 <script type="text/javascript">
 2             function MyClass(){
 3             }
 4             
 5             MyClass.prototype.a = 123;
 6             MyClass.prototype.sayHello = function(){
 7                 alert("Hello");
 8             };
 9             var mc = new MyClass();
10             var mc2 = new MyClass();
11             /*console.log(MyClass.prototype);
12             console.log(MyClass());*/
13             console.log(mc2.__proto__ == MyClass.prototype);
14             mc.a = "我是mc中的a";
15             console.log(mc2.a);
16             console.log(mc2.__proto__.a);
17             console.log(mc.a);
18             console.log(mc.__proto__.a);
19         </script>

 

2、使用in檢查對象中是否含有某個屬性時,如果對象中沒有但是原型中有,也會返回true

可以使用對象的hasOwnProperty()來檢查對象自身中是否含有該屬性

使用該方法只有當對象自身中含有屬性時,才會返回true

3、原型對象也是對象,所以它也有原型,

當我們使用一個對象的屬性或方法時,會先在自身中尋找,自身中有,則直接使用,

如果沒有則去原型對象中尋找,如果原型對象中有,則使用

如果沒有則去原型的原型中去尋找,直到找到Object對象的原型

Object對象的原型沒有原型,如果在Object原型中依然沒有找到,則返回underfined

 1 <script type="text/javascript">
 2             function MyClass(){
 3             }
 4             MyClass.prototype.name = "我是原型中的名字";
 5             var mc = new MyClass();
 6             mc.age = 123;
 7             console.log(MyClass.prototype);
 8             console.log(mc.name);
 9             console.log("name" in mc);
10             console.log(mc.hasOwnProperty("name"));
11             console.log(mc.hasOwnProperty("age"));
12             console.log("hasOwnProperty" in mc);
13             console.log(mc.hasOwnProperty("hasOwnProperty"));
14             console.log(mc.__proto__.hasOwnProperty("hasOwnProperty"));
15             console.log(mc.__proto__.__proto__.hasOwnProperty("hasOwnProperty"));
16             
17         </script>

 


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

-Advertisement-
Play Games
更多相關文章
  • 1:問題: 假如在做一個管理系統,面向老師學生的,學生提交申請,老師負責審核(或者還需要添加其他角色,功能許可權都不同)。 現在的問題是,每種角色登錄看到的界面應該都是不一樣的,那這個頁面的區分如何實現呢? 2:要不要給老師和學生各自設計一套頁面?這樣工作量是不是太大了,並且如果還要加入其它角色的話, ...
  • 清除浮動: 在非IE瀏覽器下,當容器的高度為auto,且容器的內容中有浮動(float為left或right)的元素,在這種情況下,容器的高度不能自動伸長以適應內容的高度,使得內容溢出到容器外面而影響(甚至破壞)佈局的現象。即父級對象盒子無法被撐開,這個現象叫浮動溢出,為了防止這個現象的出現而進行的 ...
  • var Arry=[ {name: "vehicleTravelLicenseCopyBack", id: "a1"}, {name: "vehicleTravelLicenseCopyFront", id: "a2"}, {name: "idCardBack", id: "a3"}, {name: ...
  • 本文由雲+社區發表 “當我第一次知道要這篇文章的時候,其實我是拒絕的,因為我覺得,你不能叫我寫馬上就寫,我要有乾貨才行,寫一些老生常談的然後加上好多特技,那個 Node.js 性能啊好像 Duang~ 的一下就上去了,那讀者一定會罵我,Node.js 根本沒有這樣搞性能優化的,都是假的。” 斯塔克· ...
  • 聲明 本篇內容全部摘自阮一峰的: "ECMAScript 6 入門" 阮一峰的這本書,我個人覺得寫得挺好的,不管是描述方面,還是例子,都講得挺通俗易懂,每個新特性基本都還會跟 ES5 舊標準做比較,說明為什麼會有這個新特性,這更於理解。 所以,後續不會再寫個關於 ES6 系列的文章了,就在這篇里大概 ...
  • 本文主要介紹了React事件處理的機制及原理,具有一定的參考價值,對此有需要的朋友可以參考學習下。如有不足之處,歡迎批評指正。 React中的事件處理在React元素中綁定事件有兩點需要註意: (1)在React中,事件命名採用駝峰命名方式,而不是DOM元素中的小寫字母命名方式。例如onclick要 ...
  • v-model 指令在表單控制項元素上創建雙向數據綁定,所謂雙向綁定,指的就是我們在js中的vue實例中的data與其渲染的dom元素上的內容保持一致,兩者無論誰被改變,另一方也會相應的更新為相同的數據 最基礎的就是實現一個聯動的效果 checkbox v-bind 有些指令可以在其名稱後面帶一個“參 ...
  • 在vue.js項目中,經常需要對數據實時更新——每隔xx秒需要刷新一次介面——即需要用到定時器相關原理。這篇文章主要介紹了vue項目每30秒刷新1次介面的實現方法,具有一定的參考價值,對此有需要的朋友可以參考學習下。如有不足之處,歡迎批評指正。 在vue.js項目中,經常需要對數據實時更新——每隔x ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...