前端創建對象?

来源:https://www.cnblogs.com/cjx-web/archive/2018/07/28/9379729.html
-Advertisement-
Play Games

雖然Object構造函數或者對象字面量都可以創建單個對象,但是這些方式有個明顯的缺點:使用同一個介面創建很多對象,會產生大量的重覆代碼,為瞭解決這個問題,現在很多人創建了很多不同的模式來解決這個問題 1>工廠模式:工廠模式是軟體工程領域一種廣為人知的設計模式,這種模式抽象創建具體對象的過程 2>構造 ...


雖然Object構造函數或者對象字面量都可以創建單個對象,但是這些方式有個明顯的缺點:使用同一個介面創建很多對象,會產生大量的重覆代碼,為瞭解決這個問題,現在很多人創建了很多不同的模式來解決這個問題

 

 

     1>工廠模式:工廠模式是軟體工程領域一種廣為人知的設計模式,這種模式抽象創建具體對象的過程

function CreatPerson(name,age,job) {
    var o=new Object();
    o.name=name;
    o.age=age;
    o.job=job;
    o.sayName=function () {
        console.log(this.name);
    };
    return o;
}

var person1=new CreatPerson('kobe',39,'player');
person1.sayName();

 

2>構造函數模式:經歷4個步驟1>創建一個新對象2>將構造函數的作用域賦給新對象(因此this就指向這個新對象)3>執行構造函數中的代碼(為這個新對象添加屬性)4>返回新對象

           構造函數就是你用new創建對象時調用的函數。使用構造函數的好處在於所有用同一個構造函數創建的對象都具有同樣的屬性和方法。

 

function Person(name) {
    this.name=name;
    this.sayName=function () {
        console.log(this.name);
    }
}
var person1=new Person('kobe');
var person2=new Person('james');

console.log(person1.name);
console.log(person2.name);

person1.sayName();
person2.sayName();

console.log(person1 instanceof Person);

console.log(person2 instanceof Person);
 

 

 

 

3>原型對象:將信息直接添加在原型對象上,我們創建的每個函數都有一個prototype屬性,這個屬性是一個指針,指向一個對象,而這個對象的用途的就是可以讓所有實例對象共用它所包含的屬性和方法

      缺點:使用原型,所有實例對象都有共同的屬性和方法,所有會造成不好的影響,

 

 1 Person.prototype= {
 2     name:'kobe',
 3     age:39,
 4     sayName:function () {
 5         console.log(this.name+'---'+this.age);
 6     }
 7 }
 8 
 9 var person1=new Person();
10 person1.sayName();

 


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

-Advertisement-
Play Games
更多相關文章
  • [1]按鍵 [2]電池使用 [3]觸摸板 [4]調度中心 [5]快捷鍵 [6]軟體設置 [7]常用功能 ...
  • 回想我寫的node.js和MongoDB的博客,都是菜鳥教程那裡的知識,所以我打算不寫了,那些都是基礎,在項目開發中,我發現單單有那些基礎不行,這些基礎可以儘快學好,然後學習項目開發過程 下麵是兩個教程的鏈接: https://www.runoob.com/nodejs/nodejs-tutoria ...
  • function show(){ document.addEventListener("click",fn,{ "passive":false, "capture":false, "once":true }); "passive" 就是告訴瀏覽器 我可不可以用 stopPropagation 在執行 ...
  • 1、onclick="javascript:window.location.href='aa.htm' " 2、onclick="location='URL' " 1、onclick="javascript:window.location.href='aa.htm' " 2、onclick="loc ...
  • parent() 、parents()、closest() 區別示例: 滑鼠移動到 a 上去,立即顯示文字提示效果:this 當前對象,e 滑鼠 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3 ...
  • 使用vscode編輯vue文件時發現突然格式化代碼不會對<template> </template>之間的html生效了,解決辦法很簡單 文件 --> 首選項 > 設置 搜索 vetur.format.defaultFormatter.html (前提當然是你已經裝了 "vetur" 插件) 可以看 ...
  • 在WebApp或瀏覽器中,會有點擊返回、後退、上一頁等按鈕實現自己的關閉頁面、調整到指定頁面、確認離開頁面或執行一些其它操作的需求。可以使用 popstate 事件進行監聽返回、後退、上一頁操作。 一、簡單介紹 history 中的操作 1.window.history.back(),後退 2.wi ...
  • DOM,文檔對象模型。是HTML和XML文檔的編程介面。它給文檔(結構樹)提供了一個結構化的表述並且定義了一種方式—程式可以對結構樹進行訪問,以改變文檔的結構,樣式和內容。 DOM 提供了一種表述形式將文檔作為一個結構化的節點組以及包含屬性和方法的對象。從本質上說,它將web 頁面和腳本或編程語言連 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...