日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 前端技术 > javascript >内容正文

javascript

JavaScript 设计模式之构造函数模式

發布時間:2023/12/10 javascript 30 豆豆
生活随笔 收集整理的這篇文章主要介紹了 JavaScript 设计模式之构造函数模式 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

一、構造函數模式概念解讀

? 1.構造函數模式概念文字解讀

????? 構造函數用于創建特定類型的對象——不僅聲明了使用的對象,構造函數還可以接受參數以便第一次創建對象的時候設置對象的成員值。你可以自定義自己的構造函數,然后在里面聲明自定義類型對象的屬性或方法。

????? 在JavaScript 里,構造函數通常是認為用來實現實例的,JavaScript沒有類的概念,但是有特殊的構造函數。通過new 關鍵字來調用自定義的構造函數,在構造函數內部,this 關鍵字引用的是新創建的對象。

? 2.構造函數模式概念擬物化解讀

???? 門創建出來是要歸屬于某個人的,即,有使用對象(小王或小李)。門可以有多把鑰匙。門可以有各種花邊和形狀。

??? (廠家原始的門,客戶要求的門)

二、構造函數模式的作用和注意事項

? 模式作用:

??? 1.用于創建特定類型的對象。

??? 2.第一次聲明的時候給對象賦值。

??? 3.自己聲明構造函數,賦予屬性和方法。

? 注意事項:

??? 1.聲明函數的時候處理業務邏輯。

??? 2.區分和單例的區別,配合單例實現初始化。

??? 3.構造函數建議大寫字母開頭。

??? 4. 注意new 的成本。(繼承)盡量把公用的功能放到原型上去,具體再擴展。

?

三、構造函數模式的代碼實戰和總結

?1.一個通俗的例子

<meta charset="utf-8"/> <script type="text/javascript">//1.用于創建特定類型的對象//2.js開發的時候寫單引號//造門function makeDoor(){//instanceof 指向當前父類if (!(this instanceof makeDoor)) {return makeDoor();};this.lock="普通"; //門上的鎖this.figure="普通"; //門上的花紋this.create=function(){ //開始產門return "【鎖頭】"+this.lock+"【花紋】"+this.figure;}}var xiaozhangjia=new makeDoor(); //小張家需要建門,//此處如果沒有new ,會出現//“JS_singleton.html:46 Uncaught RangeError: Maximum call stack size exceeded”//堆棧溢出的錯誤。alert("xiaozhangjia"+xiaozhangjia.create()); //開始產門 </script>

?

?2.與單例模式配合的例子

<meta charset="utf-8"/> <script type="text/javascript">//1.用于創建特定類型的對象//2.js開發的時候寫單引號//聲明一個AA公司,造門;將造門放到AA進來,略改一下語法var AA={ //造門function:makeDoor(figure){//instanceof 指向當前父類if (!(this instanceof makeDoor)) {return new makeDoor();};var _figure = "普通";if (figure) {_figure= figure;};this.lock="普通"; //門上的鎖this.figure=_figure; //門上的花紋this.create=function(){ //開始產門return "【鎖頭】"+this.lock+"【花紋】"+this.figure}} //聲明一個BB公司,也可以造門var BB={ //造門function : makeDoor(figure){//instanceof 指向當前父類if (!(this instanceof makeDoor)) {return new makeDoor();};var _figure = "普通";if (figure) {_figure= figure;};this.lock="普通"; //門上的鎖this.figure=_figure; //門上的花紋this.create=function(){ //開始產門return "【鎖頭】"+this.lock+"【花紋】"+this.figure}}var xiaozhangjia=new AA.makeDoor(); //小張家需要建門,//此處如果沒有new ,會出現//“JS_singleton.html:46 Uncaught RangeError: Maximum call stack size exceeded”//堆棧溢出的錯誤。alert("xiaozhangjia"+xiaozhangjia.create()); //開始產門var xiaolijia =new BB.makeDoor('絢麗');//小李家也需要建門,alert("xiaolijia"+xiaolijia.create()); </script>

?

總結

以上是生活随笔為你收集整理的JavaScript 设计模式之构造函数模式的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。