面向对象的尝试
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>test</title> <style type="text/css"> #wrap div,#wrap2 div{ width:180px; height:150px; background: red; display: none;} .active{background: #fcc; color: #fff;} </style> </head> <body> <div id="wrap"> <a href="#">左</a> <button>111</button><button>222</button><button>333</button> <a href="#">右</a> <div>11111111</div><div>2222222222</div><div>33333333333</div> </div> <div id="wrap2"> <a href="#">左</a> <button>111</button><button>222</button><button>333</button> <a href="#">右</a> <div>11111111</div><div>2222222222</div><div>33333333333</div> </div> </body> </html> <script type="text/javascript"> function tab(obj){ var _this=this; this.inow=0; this.oWrap=document.getElementById(obj); this.aBtn=this.oWrap.getElementsByTagName("button"); this.aDiv=this.oWrap.getElementsByTagName("div"); this.aArr=this.oWrap.getElementsByTagName("a"); this.aArr[1].onclick=function(){ _this.inow++; if(_this.inow==_this.aBtn.length){_this.inow=0}; _this.fnclick(_this.inow); } this.aArr[0].onclick=function(){ _this.inow--; if(_this.inow==-1){_this.inow=_this.aBtn.length-1}; _this.fnclick(_this.inow); } this.fnclick(this.inow); } //初始化方法 tab.prototype.init = function(num) { this.defaultstate(); this.aBtn[num].className="active"; this.aDiv[num].style.display="block"; } //恢复默认css状态 tab.prototype.defaultstate=function(){ for (var j = 0; j < this.aBtn.length; j++) { this.aBtn[j].className=""; this.aDiv[j].style.display="none"; } } //初始化和点击 tab.prototype.fnclick = function(n){ this.init(n); var _this=this; for (var i = 0; i < this.aBtn.length; i++) { this.aBtn[i].index=i; this.aBtn[i].onclick=function(){ _this.inow=this.index; _this.defaultstate(); _this.init(_this.inow); } }; } var s1= new tab("wrap"); var s1= new tab("wrap2"); </script>
对我这种值追求结果的人来说,用什么方法实现是不关注的,但是今天看了一个大神用面向对象的方法写js效果,感觉思路真是他妈的清晰,不得不爱呀,实际上我写的时候,感觉怎么那么的别扭。可能是我一直都对概念性的东西不感兴趣从而导致对概念理解不清楚,就想这个例子里面我也不知道把左右的按钮写在哪里,因为在我心里就没有面向对象的概念,其实在我心里还是感觉怎么方便怎么写,不过我看大神面向对象的思路确实很清楚,思路一清晰,丫的,思路清晰感觉代码都干净,于是今天下午就自己写了一个选项卡,说起来,选项卡都被前端做例子写懒了,哈哈...
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步