欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

javascript 寫(xiě)類方式之十

 更新時(shí)間:2009年07月05日 01:52:04   作者:  
mootools.js的最新版本是1.2.3,這里使用的是1.2.0。mootool被設(shè)計(jì)成非常緊湊的,模塊化的,面向?qū)ο蟮牡膉s庫(kù)。mootool中寫(xiě)類用Class類。
10、mootools.js的寫(xiě)類方式
mootools.js的最新版本是1.2.3,這里使用的是1.2.0。mootool被設(shè)計(jì)成非常緊湊的,模塊化的,面向?qū)ο蟮牡膉s庫(kù)。mootool中寫(xiě)類用Class類。Class類由Native類new出來(lái)的:
復(fù)制代碼 代碼如下:

/*
*Script: Class.js
*/
var Class = new Native({
name: 'Class',

initialize: function(properties){
properties = properties || {};
var klass = function(empty){
for (var key in this) this[key] = $unlink(this[key]);
for (var mutator in Class.Mutators){
if (!this[mutator]) continue;
Class.Mutators[mutator](this, this[mutator]);
delete this[mutator];
}
this.constructor = klass;
if (empty === $empty) return this;

var self = (this.initialize) ? this.initialize.apply(this, arguments) : this;
if (this.options && this.options.initialize) this.options.initialize.call(this);
return self;
};

$extend(klass, this);
klass.constructor = Class;
klass.prototype = properties;
return klass;
}
});

Native方法是mootools中一個(gè)非常重要的方法,很多類都用它去組裝。如Window,Document,Event。當(dāng)然還有這里的Class,導(dǎo)入mootools后我們寫(xiě)類時(shí)只需要用Class就行了。一個(gè)Person類:
復(fù)制代碼 代碼如下:

/**
* Person類
* @param {Object} name
*/
var Person = new Class({
initialize: function(name){
this.name = name;
},
setName : function(name) {
this.name = name;
},
getName : function() {
return this.name;
}
})

//new一個(gè)對(duì)象
var p = new Person("jack");

//測(cè)試set,get方法
console.log(p.getName());//jac
p.setName('andy');
console.log(p.getName());//andy

//測(cè)試instanceof及p.constructor是否正確指向了Person
console.log(p instanceof Person); //true
console.log(p.constructor == Person); //true

Native實(shí)際上只是一個(gè)普通函數(shù),它通過(guò)所傳參數(shù)組裝了一個(gè)類(function),最后返回該類(function)。既然Native是函數(shù),函數(shù)調(diào)用的方式是(),call,apply。但在mootools中卻用new Native(obj)方式。為何?原因只是使Native看起來(lái)更像一個(gè)類而已。
  • javascript Base類 包含基本的方法

    javascript Base類 包含基本的方法

    一個(gè)Base類,包含基本的方法,大家可以在這個(gè)基礎(chǔ)上拓展下功能。
    2009-07-07
  • javascript類繼承機(jī)制的原理分析

    javascript類繼承機(jī)制的原理分析

    本文著重解析javascript類繼承機(jī)制,讓你從底層了解javascript是怎樣實(shí)現(xiàn)“繼承”這一概念的。
    2009-09-09
  • JavaScript 面向?qū)ο笕腴T(mén)精簡(jiǎn)篇

    JavaScript 面向?qū)ο笕腴T(mén)精簡(jiǎn)篇

    圍繞面向?qū)ο蟮膸状箨P(guān)鍵字:封裝 ,繼承 ,多態(tài) ,展開(kāi)JavaScript面向?qū)ο?/div> 2009-03-03
  • javascript面向?qū)ο笾?命名空間

    javascript面向?qū)ο笾?命名空間

    javascript中本沒(méi)有命名空間的概念,但是要體現(xiàn)面向?qū)ο蟮乃枷耄瑧?yīng)當(dāng)有命名空間,就像java中的package,.net中的namespace一樣,作用主要為了防止類名沖突,相同的類名只要屬于不同的命名空間,便不會(huì)沖突。
    2011-02-02
  • JavaScript isPrototypeOf和hasOwnProperty使用區(qū)別

    JavaScript isPrototypeOf和hasOwnProperty使用區(qū)別

    JavaScript isPrototypeOf和hasOwnProperty的使用技巧,需要的朋友的朋友可以參考下。
    2010-03-03
  • JS類定義原型方法的兩種實(shí)現(xiàn)的區(qū)別評(píng)論很多

    JS類定義原型方法的兩種實(shí)現(xiàn)的區(qū)別評(píng)論很多

    JS類定義原型方法的兩種實(shí)現(xiàn)的區(qū)別評(píng)論很多...
    2007-09-09
  • javascript 寫(xiě)類方式之三

    javascript 寫(xiě)類方式之三

    用構(gòu)造函數(shù)來(lái)定義類屬性(字段) 用原型方式來(lái)定義類的方法。 就有了第三種方式。這種方式貌似采用的人較多。
    2009-07-07
  • 一實(shí)用的實(shí)現(xiàn)table排序的Javascript類庫(kù)

    一實(shí)用的實(shí)現(xiàn)table排序的Javascript類庫(kù)

    一實(shí)用的實(shí)現(xiàn)table排序的Javascript類庫(kù)...
    2007-09-09
  • Javascript 面向?qū)ο螅ǘ┓庋b代碼

    Javascript 面向?qū)ο螅ǘ┓庋b代碼

    Javascript 面向?qū)ο螅ǘ┓庋b代碼,需要的朋友可以參考下
    2012-05-05
  • 最新評(píng)論