ES6 使用面向对象实现选项卡

选项卡样子


<html>

<head>
<title>ES6面向对象</title>
<style>
input.active{
   background:red;
}
#first > div {
    width:200px;
	height:200px;
	background:#ccc;
	display:none;
}
#first > div:first-of-type{
   display:block;
}
</style>

</head>

<body>
	<div id="first">
		<input type="button" value="1" class="active">
		<input type="button" value="2">
		<input type="button" value="3">
		<div>第一个界面</div>
		<div>第二个界面</div>
		<div>第三个界面</div>
	</div>
	
	<script>
		class Tab{
		  constructor(id){
			//1.选中摸一个区域内的元素
			this.all = document.getElementById(id);
			//2.获取所有的input
			this.allInput = this.all.getElementsByTagName('input');
			//3.获取所有的div
			this.allDiv = this.all.getElementsByTagName('div');
			this.init();
		  }
		  
		  init(){
			//4.为所有的input添加事件
			for(let i=0;i<this.allInput.length;i++){
				this.allInput[i].onclick = function(){
				  this.hide();
				  this.show(i);
				}.bind(this);
			}
		  }
		  
		  //显示
		  show(index){
			this.allInput[index].className = 'active';
			this.allDiv[index].style.display = 'block';
		  }
		  
		  //隐藏
		  hide(){
			for(let i=0;i<this.allInput.length;i++){
				this.allInput[i].className = '';
			}
			
			for(let j=0;j<this.allDiv.length;j++){
				this.allDiv[j].style.display = 'none';
			}
		  }
		}

		new Tab('first');
	</script>
</body>

</html>



  • 1
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值