学习javascript设计模式之单例模式
1、单例模式的核心是确保只有一个实例,并提供全局访问。
2、惰性单例 指的是在需要的时候才创建对象实例。
如在页面中创建唯一div 普通做法
var createDiv = (function(){
var div;
return function(){
if(!div){
div = document.createElement("div");
div.style.width="100px";
div.innerHTML = "fdsafdsafdsafdsa";
div.style.display = 'none';
document.body.appendChild(div);
return div;
}
return div;
}
})();
document.getElementById("btn").onclick = function(){
var loginlayer = createDiv();
loginlayer.style.display = 'block';
}
应用通用惰性单例
var getSingle = function(fn){
var result;
return function(){
return result || (result = fn.apply(this,arguments));
}
}
var createDiv = function(){
var div = document.createElement("div");
div.style.width="100px";
div.innerHTML = "fdsafdsafdsafdsa";
document.body.appendChild(div);
return div;
}
var createSingleDiv = getSingle(createDiv);
document.getElementById("btn").onclick = function(){
var loginlayer = createSingleDiv();
loginlayer.style.display = 'block';
}
最新文章
- maven集成tomcat插件以及乱码解决
- ACM ICPC Vietnam National Second Round
- 【hive】——Hive初始了解
- MAC下搭建及使用XAMPP的详细教程
- Mac环境下svn的使用
- [转]easyui tree 模仿ztree 使用扁平化加载json
- Android MultiDex兼容包怎么使用?
- iOS-布局-Masonry
- 循序渐进开发WinForm项目(3)--Winform界面层的项目设计
- Codeforces Round #379 (Div. 2) C. Anton and Making Potions 二分
- div+css文字垂直居中 解决左侧头像右侧姓名,姓名多换行后相对于头像仍居中显示
- Docker存储驱动之OverlayFS简介
- JS数组及内置对象
- Docker学习笔记 - Docker Compose 脚本命令
- centos7系统下hostname解析
- aws平台中为ec2实例添加双网卡
- linux安装jdk、tomcat、maven、mysql
- 【opencv基础】imwrite函数与图像存储质量
- 在Visual Studio中使用类图描述领域模型
- Adobe edge animate制作HTML5动画可视化工具(一)
热门文章
- HashMap与ArrayMap(和SparseArray)的比较与选择
- 使用MySQL yum源安装MySQL
- paper:synthesizable finite state machine design techniques using the new systemverilog 3.0 enhancements 之 standard verilog FSM conding styles(二段式)
- thinkphp5中php7中运行会出现No input file specified. 这个你改个东西
- 20个必不可少的Python库也是基本的第三方库
- Applied Nonparametric Statistics-lec4
- Java并发编程的艺术 记录(三)
- Stall Reservations POJ - 3190 (贪心+优先队列)
- MIP启发式算法:Variable neighborhood search
- HDU 5473 There was a kingdom 凸包 DP