javascript 面向对象编程小记

虽然平常用jquery用的很熟,但是基本都是面向过程的写法。一个事件一个function,很少有面向对象的写法。今天得写一个日期控件,不得不用上面向对象编程。

刚开始我的想法是:

复制代码
var datepicker = function(){
    return new datepicker.fn.init();
}

datepicker.fn =  datepicker.prototype={
    constructor:datepicker,
    init:function(){

    }
}

datepicker.fn.init.prototype = datepicker.fn;

datepicker.extend =  datepicker.fn.extend = function(){};

//静态方法 datepicker.extend({ createHtml:
function(){ } });
复制代码

嗯,你没看错,就是仿照Jquery的写法。

但是,事实上,还是我学艺不精,extend里的方法根本无法继承。

这种写法的本意是将extend里的静态方法当成参数,传到extend方法里,然后根据具体的方法名返回相应的function。

而我写的代码里根本就忽略了extend方法,以为只要是一个空的function就可以了。

关于jquery的核心代码以及框架,还是看一下链接吧:

http://nuysoft.iteye.com/blog/1182087

 

所以我还是老老实实的用普通的prototype方法写吧。

复制代码
var datePicker = function(){
    this.init();
}

// 静态方法 datePicker.prototype
= { init:function(){ alert(11111); } };
复制代码

其实这种写法,也能够将多个静态方法封装起来,当成一个json对象,挂载到prototype里。

然后在创建对象的时候,就可以直接利用this来调用了。

 

posted @   のんきネコ  阅读(176)  评论(0编辑  收藏  举报
编辑推荐:
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
阅读排行:
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· 单线程的Redis速度为什么快?
点击右上角即可分享
微信分享提示