首页 > 编程语言 > 详细

这2段有关javascript函数化模式【模块化模式】的总结,还需要好好地琢磨!!!

时间:2014-11-03 18:57:10      阅读:207      评论:0      收藏:0      [点我收藏+]

<script>
Function.prototype.method = function (name, func) {
if (!this.prototype[name]) {
this.prototype[name] = func;
}
};
Object.method(‘superior‘, function (name) {
var that = this,
method = that[name];
return function ( ) {
return method.apply(that, arguments);
};
});
var mammal = function (spec) {
var that = {};
that.get_name = function ( ) {
return spec.name;
};
that.says = function ( ) {
return spec.saying || ‘‘;
};
return that;
};
//var myMammal = mammal({name: ‘Herb‘});
var cat = function (spec) {
spec.saying = spec.saying || ‘meow‘;
var that = mammal(spec);
that.purr = function (n) {
var i, s = ‘‘;
for (i = 0; i < n; i += 1) {
if (s) {
s += ‘-‘;
}
s += ‘r‘;
}
return s;
};
that.get_name = function ( ) {
return that.says( ) + ‘ ‘ + spec.name +
‘ ‘ + that.says( );
}
return that;
};
var myCat = cat({name: ‘Henrietta‘});
var coolcat = function (spec) {
var that = cat(spec),
super_get_name = that.superior(‘get_name‘);
that.get_name = function (n) {
return ‘like ‘ + super_get_name( ) + ‘ baby‘;
};
return that;
};

var myCoolCat = coolcat({name: ‘Bix‘});
var name = myCoolCat.get_name( );
// ‘like meow Bix meow baby‘

</script>
<script>
function createCar(numberOfDoors){
var numberOfWheels = 4;
function describe(){
return "I have " + numberOfWheels + " wheels and " + numberOfDoors + " doors.";
}
return {
describe: describe
};
}
function createOdometer(){
var mileage = 0;
function increment(numberOfMiles){ mileage += numberOfMiles;}
function report(){ return mileage; }
return {
increment: increment,
report: report
}
}

function createCarWithOdometer(numberOfDoors){
var odometer = createOdometer();
var car = createCar(numberOfDoors);
car.drive = function(numberOfMiles){
odometer.increment(numberOfMiles);
}
car.mileage = function(){
return "car has driven " + odometer.report() + " miles";
}
return car;
}


var twoFn=createCarWithOdometer(100);


console.log(twoFn);

 

</script>

 

这2段有关javascript函数化模式【模块化模式】的总结,还需要好好地琢磨!!!

原文:http://www.cnblogs.com/dingyuanxin/p/4071799.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!