位置: 编程技术 - 正文

javascript 单例模式演示代码 javascript面向对象编程(js编写一个标准的单例模式类)

编辑:rootadmin
js的单例写法 JS单例模式 你是?(单例) 你是?(普通) [Ctrl+A 全选 注:如需引入外部Js需刷新才能执行]loop.js是一个单例模式的js类://一开始就用new 无名类的方式创建。这样就实现了单例的功能。var loop = new (function(){ // 外部公共函数 // 无限循环的操作 this.setloop = function(fn){Infinite_loop.setLoopFn(fn);} // 参数 1 参数类型 function this.deleteloop = function(fn){Infinite_loop.deleteLoopFn(fn);} // 参数 1 参数类型 function this.stoploop = function(){Infinite_loop.stopLoop();} // 单次循环的操作 this.setloopOne = function(fn){one_loop.setLoopOneFn(fn);} // 参数 1 参数类型 function this.stoploopOne = function(){one_loop.stopLoopOne();} // 下面是两个私有的单例模式成员 // 无限循环执行的List对象 var Infinite_loop = new (function(){ this.loop_stop = true; this.loop_action = new Array(); this.loop_actionID = 0; var opp = this; this.setLoopFn = function(fn){ if(typeof(fn)!="function"){ throw new Error("window.loop.setloop's argment is not a function!"); return; } for(var i=0;i<this.loop_action.length;i++){ if(this.loop_action[i] == fn){ throw new Error(fn+" has been registered !"); return; } } this.loop_action.push(fn); this.startLoop(); }; this.deleteLoopFn = function(fn){ for(var i=0;i<this.loop_action.length;i++){ if(this.loop_action[i] == fn){ this.loop_action.splice(i,1); } } }; this.Loop = function(){ var run = function(){ if(opp.loop_action.length > 0){ (opp.loop_action[opp.loop_actionID])(); opp.loop_actionID++; if(opp.loop_actionID>=opp.loop_action.length)opp.loop_actionID=0; setTimeout(opp.Loop,); return; } opp.loop_stop = true; }; run(); } this.stopLoop = function(){ this.loop_stop = true; } this.startLoop = function(){ if(! this.loop_stop)return; this.loop_stop = false; this.Loop(); } })(); /* 单次执行的list对象 */ var one_loop = new (function(){ this.loopOne_stop = true; this.loopOne_action = new Array(); var opp = this; this.setLoopOneFn = function(fn){ if(typeof(fn)!="function"){ throw new Error("window.loop.setloopOne's argment is not a function!"); return; } this.loopOne_action.push(fn); this.startLoopOne(); } this.LoopOne = function(){ function run(){ if(opp.loopOne_action.length>0 && !opp.loopOne_stop){ (opp.loopOne_action.shift())(); setTimeout(opp.LoopOne,); return; } opp.loopOne_stop = true; } run(); } this.stopLoopOne = function(){ this.loopOne_stop = true; } this.startLoopOne = function(){ if(! this.loopOne_stop)return; this.loopOne_stop = false; this.LoopOne(); } })();})();下面是实例:loop.html<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" " xmlns=" http-equiv="Content-Type" content="text/html; charset=utf-8" /><title>loop.js</title><script type="text/javascript" src="jquery.js"></script><script type="text/javascript" src="loop.js"></script><script type="text/javascript">function moveLayer1(){ this.moveleft = true; this.movedown = true; this.x1 = this.y1 = ; this.x2 = ; this.y2 = ;}moveLayer1.prototype.move = function(){ var divLayer1 = document.getElementById("Layer1"); var l = parseInt(divLayer1.style.left), t = parseInt(divLayer1.style.top); var r = parseInt(Math.random()*); if(l < this.x2 && this.moveleft){ l+=1+r; if(l>this.x2-1)this.moveleft = false; }else if(l > this.x1 && ! this.moveleft){ l-=1+r; if(l < this.x1+1)this.moveleft = true; } if(t < this.y2 && this.movedown){ t+=1+r; if(t>this.y2-1)this.movedown = false; }else if(t > this.y1 && ! this.movedown){ t-=1+r; if(t < this.y1+1)this.movedown = true; } divLayer1.style.left =l+"px"; divLayer1.style.top = t+"px";}function circle(){ this.r = ; this.rx = ; this.ry = ; this.x; this.y; this.angle = 0; this.speedAngle = ;}circle.prototype.init = function(){ this.setXY(); $("body").append('<div id="cd" class="Layer2" style="left:'+this.x+'px;top:'+this.y+'px;"><img src="testFile/glass_x.gif" /></div>'); $("body").append('<div class="Layer1" style="left:'+this.rx+'px;top:'+this.ry+'px;"></div>');}circle.prototype.setXY = function(){ this.x = this.rx + this.r*Math.cos(this.angle/(/Math.PI)); this.y = this.ry + this.r*Math.sin(this.angle/(/Math.PI));}circle.prototype.draw = function(){ this.angle +=this.speedAngle; this.setXY(); var f = document.getElementById("cd"); //$("body").append($("#cd").clone()); f.style.left =this.x+"px"; f.style.top = this.y+"px";}function timetable(){var f = document.getElementById("daa");var d = new Date();f.innerHTML = "现在时间:"+d.getUTCFullYear()+"年"+d.getUTCMonth()+"月"+d.getUTCDate()+"日 星期"+d.getUTCDay()+" "+d.getUTCHours()+":"+d.getUTCMinutes()+":"+d.getUTCSeconds();}var lenstr = -1;function prints(){ var str = document.getElementById("sourse").innerHTML; if(lenstr<str.length){ lenstr++; var f = document.getElementById("prin"); //if(lenstr%==0)f.innerHTML +="<br />"; f.innerHTML += str.charAt(lenstr); }else{ loop.deleteloop(prints); }}var movediv = new moveLayer1();function imgMove(){movediv.move();}var mycircle = new circle();function drawCircle(){mycircle.draw();}function winInit(){mycircle.init();loop.setloop(drawCircle);loop.setloop(imgMove);loop.setloop(timetable);loop.setloop(prints);}</script><style type="text/css"><!--.Layer1 { position:absolute; overflow:hidden; color:#fff; width:px; height:px; z-index:;}.Layer2 { position:absolute; overflow:hidden; color:#fff; width:px; height:px; z-index:1;}--></style></head><body onload="winInit();"><div id="daa"></div><div id="Layer1" class="Layer1" style="left:px; top:px;"><img src="testFile/glass_x.gif" name="mimg" width="" height="" id="mimg" /></div><pre id="prin"></pre><div id="sourse" style="display:none"> var x = 1; var y = 2; var z = 3; var sum; function Plus(a, b) { var z = 0; var i = 0; for (i = 0; i < arguments.length; i++) { z += arguments[i]; } setTimeout( function() {alert(z);}, ); //可以带变量参数的setTimeout调用形式 return z; } setTimeout( function(){ sum = Plus(x, y, z); }, ); /*除了可以带变量参数还可以获取返回值的setTimeout调用形式*/</div></body></html>jquery.jsjQuery 是1.2.6版的,小巧的js框架,可以到 money = factory.creater ("美元");

推荐整理分享javascript 单例模式演示代码 javascript面向对象编程(js编写一个标准的单例模式类),希望有所帮助,仅作参考,欢迎阅读内容。

javascript 单例模式演示代码 javascript面向对象编程(js编写一个标准的单例模式类)

文章相关热门搜索词:单例模式前端,js class 单例,js中单例模式,js中单例模式,js编写一个标准的单例模式类,js编写一个标准的单例模式类,js单例模式应用场景,js单例模式,内容如对您有帮助,希望把文章链接给更多的朋友!

JavaScript 设计模式之组合模式解析 怎么说呢?!就像是动物(组合对象)一样,当它生下后代(叶对象)时,它的后代就有了某种功能(比如:挖洞,听力好等等);也像是一棵树,它

javascript 对象入门实例教程 1:构造函数法[Ctrl+A全选注:如需引入外部Js需刷新才能执行]注解:1:这里定义了一个Dog对象(在javascript中,函数就是对象,这里functionDog(name,weight)同时

JavaScript之信息的封装 js对象入门 JavaScript之信息的封装在编码前,我们需要了解如下几个术语;封装:对内部数据的表现形式和实施细节进行隐藏;私有属性和方法:外界只能通过其公

标签: js编写一个标准的单例模式类

本文链接地址:https://www.jiuchutong.com/biancheng/386536.html 转载请保留说明!

上一篇:Javascript 类与静态类的实现(续)(js类的静态属性)

下一篇:JavaScript 设计模式之组合模式解析(js设计模式有什么用)

  • 即征即退需要缴纳税款吗
  • 土地原值要计入房产税计税@基数吗
  • 发票勾选认证必须对应当期成本吗
  • 股东所有者权益公式
  • 个税系统中的离线算税和在线算税结果一样吗
  • 待摊费用和预提费用是按照什么而设置的账户
  • 外贸企业申报出口退税时的会计分录
  • 不同组织的区别主要体现在哪些方面
  • 当期进项税额大于销项税额
  • 建筑业收入确认条件
  • 银行里的钱没有了怎么办
  • 转让金融资产的税率
  • 工资薪金支出怎么调整
  • 方案讲解:关于员工激励的税收筹划
  • 蔬菜销售收入免增值税吗
  • 住宿专票怎么入账
  • 简易征收企业所得税几个点
  • 营改增挂靠工程项目账务处理
  • 发出商品如何做分录
  • 初级备考需要多长时间
  • 无偿获得固定资产的会计处理
  • 事业单位是否需要章程
  • 发票查出来显示不一致是为啥
  • 华为matex3爆料
  • 651错误是怎么回事
  • 企业收到财政资金
  • ghost还原问题1823
  • 结算备付金的账户是什么
  • 以租代购算固定资产吗
  • win11怎么添加字体到个性化
  • 不征税收入符合的条件
  • 如何区分货币财富和收入
  • 应付账款讲解
  • 长期挂账的其他应付款转营业外收入情况说明
  • 应付职工薪酬资产还是负债
  • framework教程
  • php面向对象的三大特征
  • 刚购入的固定资产怎么算
  • 个体户查账征收2023新政策是什么
  • 其他收益最后转入哪个科目
  • ping命令详解步骤
  • 广告片影视公司
  • 一般纳税人开普票税率是3%还是13%
  • 资产负债表中应付账款项目应根据什么填制
  • 新会计准则规定
  • mysql5.5数据库安装教程
  • 工程设备公司经营范围
  • 行政事业单位银行开户规定
  • 建筑企业需要缴纳的税种
  • 当事人对付款时间没有约定或者约定不明的
  • 暂估费用科目
  • 仓库管理人员工资属于什么费用
  • 免征的教育费附加怎么做账
  • 政府补助的内容
  • 微信收款计入现金流量吗
  • 行政事业单位计提工资怎么做账
  • 次年发放的奖金怎么入账
  • 金税盘发票全额抵扣如何做账
  • 会计一般用什么软件
  • 工业企业的材料
  • sql有什么
  • win10怎么设置开机自启软件
  • MacBook怎么恢复出厂设置
  • freebsd ip配置
  • xp系统自动升级win7
  • win7关机总是自动重启
  • win7旗舰版系统怎么样
  • linux ii
  • cocos输入框
  • 删除了c盘安全组或用户
  • node项目部署
  • js获取鼠标坐标到浏览器底部
  • 简单介绍中秋节
  • js获取设备
  • 车没交车船税上路什么后果
  • 企业所得税法里财产转让所得是什么意思
  • 电子税务局密钥不一致
  • 2018年北京个人所得税查询
  • 年报基础数据怎么查
  • 发票上纳税人识别号
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设