《設計模式 》 - 4. 原型模式( Prototype )
Javascript設計模式 - 原文連結
原型模式 ( Prototype ) :
語言 : JavaScript
JavaScript 克隆方法 :
function clone(obj) {
if (null == obj || "object" != typeof obj)
{
return obj;
}
// Date
if (obj instanceof Date)
{
var copy = new Date();
copy.setTime(obj.getTime());
return copy;
}
// Array
if (obj instanceof Array)
{
var copy = [];
var len = obj.length;
for (var i = 0; i < len; ++i)
{
copy[i] = clone(obj[i]);
}
return copy;
}
// Object
if (obj instanceof Object)
{
var copy = {};
for (var attr in obj)
{
if (obj.hasOwnProperty(attr)) copy[attr] = clone(obj[attr]);
}
return copy;
}
throw new Error("Unable to copy");
}
客戶類 :
var person = {
name : "小明",
age : "15",
eat : function(){
console.log("eating");
}
}
var clonePersonA = clone(person);
console.log(clonePersonA);
clonePersonA.eat();
程式碼圖示 :
結果顯示 :
相關文章
- 設計模式-原型模式(Prototype)設計模式原型
- 設計模式--原型模式(Prototype Pattern)設計模式原型
- C#設計模式-原型模式(Prototype Pattern)C#設計模式原型
- 一天一個設計模式(四) - 原型模式(Prototype)設計模式原型
- 一天一個設計模式(四) – 原型模式(Prototype)設計模式原型
- 建立模式 02-Prototype(原型)模式原型
- 設計模式-原型模式(Prototype)【重點:淺複製與深複製】設計模式原型
- 設計模式(原型模式)設計模式原型
- 設計模式:原型模式設計模式原型
- 設計模式-原型模式設計模式原型
- 設計模式 —— 原型模式設計模式原型
- Java設計模式-原型模式Java設計模式原型
- Java設計模式---原型模式Java設計模式原型
- 設計模式之原型模式設計模式原型
- 設計模式【5】-- 原型模式設計模式原型
- 設計模式(三)——原型模式設計模式原型
- java設計模式—原型模式Java設計模式原型
- 23種設計模式(八)-原型設計模式設計模式原型
- 設計模式之原型設計模式原型
- go設計模式之原型模式Go設計模式原型
- golang設計模式之原型模式Golang設計模式原型
- 設計模式入門:原型模式設計模式原型
- GoLang設計模式05 - 原型模式Golang設計模式原型
- 極簡設計模式-原型模式設計模式原型
- 設計模式 #3 (原型模式、建造者模式)設計模式原型
- 【設計模式(四)】建立型模式--原型模式設計模式原型
- 設計模式--原型模式及其程式設計思想設計模式原型程式設計
- 23種設計模式-原型模式(3)設計模式原型
- 設計模式(Java語言)- 原型模式設計模式Java原型
- Java設計模式之(四)——原型模式Java設計模式原型
- 設計模式快速學習(五)原型模式設計模式原型
- Rust語言之GoF設計模式:原型模式RustGo設計模式原型
- 設計模式:原型模式介紹 && 原型模式的深拷貝問題設計模式原型
- 從JavaScript學習設計模式-01原型模式JavaScript設計模式原型
- 重溫23種設計模式(11):原型模式設計模式原型
- 重學 Java 設計模式:實戰原型模式Java設計模式原型
- java23種設計模式——四、原型模式Java設計模式原型
- java中23種設計模式--原型模式(Portotype)Java設計模式原型