1. Javascript面向对象之三单例模式-《javascript设计模式》笔记
2014-12-08 16:17
267 查看
1.单例模式概述
源自百度百科对于单例模式的定义:
单例模式的意思就是只有一个实例。单例模式确保某一个类只有一个实例,而且自行实例化并向整个系统提供这个实例。这个类称为单例类。
在javascript的世界里,其实没有严格的对象和类定义,“一切皆对象”使得javascript中都是对象,不能像java,c++或者php使用特定的方法返回一个实例来实现,因此对javascript来说,我们要创造的是一个“不能被多次实例化的”对象,也就是说只能实例化一次的对象。
2.简单单例模式:
只能实例化一次的对象也就可以使用“对象字面量”的定义方式来实现:
这样定义的对象,不能使用new singleton的方式来生成另外的对象(不存在prototype和constructor属性)。
3.包含私有成员的单例模式:
如果看过之前的我写的关于类成员的文章,自然的我们就能想到用闭包来实现,既然要用的闭包,那么一定会用到函数和函数返回值,于是,这样的单例模式如下:
还记得匿名函数吗?通常在使用闭包的时候会使用,改进之后如下:
4.惰性加载(lazy loading,延迟加载)单例模式
2,3中所示单例模式定义方式都是在定义时创建的单例,这样很浪费内存,如何能在使用的时候才创建(lazy loading,更多的用于图片的延迟加载)呢?所谓惰性加载,也就是先定义,然后在某个地方才创建对象,所以必须要使用函数,我们知道在java或者php中单例模式通常使用一个静态方法来创建,同理,我们再改进一下闭包形式的定义式:
这样调用一个单例对象的方法:
singleton.getinstance().publicmethod();
这样只有在调用方法或引用属性的时候才会真正的创建unique对象,就是使用的时候比较麻烦:)
5.简单mvc代码风格
顺便在这里分享一下我写js的一个简单风格,尽管js是一个前台代码,但是就其本身而言,也可以将它的内容分为mvc(model,controller,view,关于mvc的概念请baidu/google),因此在写一个页面的js代码的时候,我会这么写:
//函数封装在此
//数据相关内容封装在此
在页面onload的时候调用controoler.init();完成初始化工作(数据加载,页面渲染,事件监听等),这样写的目的是尽量将一些相同的逻辑组织在一起,方便查找和修改,目前只是一个雏形,希望在看完《javascript设计模式》这本书之后能写一个轻量级的模型出来^_^
源自百度百科对于单例模式的定义:
单例模式的意思就是只有一个实例。单例模式确保某一个类只有一个实例,而且自行实例化并向整个系统提供这个实例。这个类称为单例类。
在javascript的世界里,其实没有严格的对象和类定义,“一切皆对象”使得javascript中都是对象,不能像java,c++或者php使用特定的方法返回一个实例来实现,因此对javascript来说,我们要创造的是一个“不能被多次实例化的”对象,也就是说只能实例化一次的对象。
2.简单单例模式:
只能实例化一次的对象也就可以使用“对象字面量”的定义方式来实现:
var singleton = { attribute:'', method:function(){} }
这样定义的对象,不能使用new singleton的方式来生成另外的对象(不存在prototype和constructor属性)。
3.包含私有成员的单例模式:
如果看过之前的我写的关于类成员的文章,自然的我们就能想到用闭包来实现,既然要用的闭包,那么一定会用到函数和函数返回值,于是,这样的单例模式如下:
var singleton = function(){ var private_attribute = ''; functioin private_method(){} return { public_attribute:'', public_method:function(){} }; }
还记得匿名函数吗?通常在使用闭包的时候会使用,改进之后如下:
var singleton = (function(){ var private_attribute = ''; functioin private_method(){} return { public_attribute:'', public_method:function(){} }; })();
4.惰性加载(lazy loading,延迟加载)单例模式
2,3中所示单例模式定义方式都是在定义时创建的单例,这样很浪费内存,如何能在使用的时候才创建(lazy loading,更多的用于图片的延迟加载)呢?所谓惰性加载,也就是先定义,然后在某个地方才创建对象,所以必须要使用函数,我们知道在java或者php中单例模式通常使用一个静态方法来创建,同理,我们再改进一下闭包形式的定义式:
var singleton = (function(){ var unique; function getinstance(){ if(!unique){ unique = construct(); return unique; } } function construct(){ var private_member; function private_method(){} return {//这里才是真正的单例对象 public_member:'', public_method:function(){} }; })();
这样调用一个单例对象的方法:
singleton.getinstance().publicmethod();
这样只有在调用方法或引用属性的时候才会真正的创建unique对象,就是使用的时候比较麻烦:)
5.简单mvc代码风格
顺便在这里分享一下我写js的一个简单风格,尽管js是一个前台代码,但是就其本身而言,也可以将它的内容分为mvc(model,controller,view,关于mvc的概念请baidu/google),因此在写一个页面的js代码的时候,我会这么写:
//函数封装在此
var controller = { init:function(){} }; //页面相关内容封装在此 var view = { table:{}, banner:{}, foot:{} };
//数据相关内容封装在此
var model = { table_data:{} }
在页面onload的时候调用controoler.init();完成初始化工作(数据加载,页面渲染,事件监听等),这样写的目的是尽量将一些相同的逻辑组织在一起,方便查找和修改,目前只是一个雏形,希望在看完《javascript设计模式》这本书之后能写一个轻量级的模型出来^_^
相关文章推荐
- Javascript面向对象之五工厂模式-《javascript设计模式》笔记 (赞)
- [转]Javascript面向对象之三单例模式-《javascript设计模式》笔记
- JavaScript高级程序设计之面向对象的程序设计之创建对象之寄生构造函数模式 第6.2.6讲笔记
- JavaScript高级程序设计之面向对象的程序设计之创建对象之工厂模式第6.2.1讲笔记
- [笔记]javascript面向对象 - 继承的几种模式
- JavaScript高级程序设计之面向对象的程序设计之创建对象之组合使用构造函数模式和原型模式 第6.2.4讲笔记
- JavaScript高级程序设计之面向对象的程序设计之创建对象之 构造函数模式第6.2.2讲笔记
- JavaScript高级程序设计之面向对象的程序设计之创建对象之原型模式 第6.2.3讲笔记
- JavaScript高级程序设计之面向对象的程序设计之创建对象之稳妥构造函数模式 第6.2.7讲笔记
- 理解javascript面向对象的基本模式
- JavaScript 中级笔记 第五章 面向对象的基础
- js 笔记 第一章在html中使用<javascript>标签 以及 html文档模式
- javascript面向对象学习笔记(一)——继承
- 读javascript设计模式笔记(一)富有表现力的javascript
- JavaScript笔记之面向对象
- javascript学习笔记[6]--面向对象
- JavaScript 学习笔记【一】——面向对象的写法分析
- javascript学习笔记(九) js对象 设计模式
- Javascript 设计模式学习笔记(2) - 继承(Inheritance) (上)
- javascript面向对象学习笔记2010.7.16