js es6系列教程 - 新的类语法实战选项卡(详解)
程序员文章站
2022-09-08 11:44:46
其实es6的面向对象很多原理和机制还是es5的,只不过把语法改成类似php和java老牌后端语言中的面向对象语法.
一、用es6封装一个基本的类
class p...
其实es6的面向对象很多原理和机制还是es5的,只不过把语法改成类似php和java老牌后端语言中的面向对象语法.
一、用es6封装一个基本的类
class person{ constructor( uname ){ this.username = uname; } sayname(){ return this.username; } }
是不是很向php和java中的类, 其实本质还是原型链,我们往下看就知道了
首先说下语法规则:
class person中的person就是类名,可以自定义
constructor就是构造函数,这个是关键字,当实例化对象的时候,这个构造函数会被自动调用
let op = new person( 'ghostwu' ); console.log( op.sayname() ); //ghostwu console.log( op instanceof person ); //true console.log( op instanceof object ); //true console.log( typeof person ); //function console.log( typeof person.prototype.sayname ); //function console.log( op.__proto__ === person.prototype ); //true console.log( 'sayname' in op ); //true console.log( person.prototype );
第1行和第2行实例化和调用方法还是跟es5一样
第4行和第5行判断对象是否是类(person)和object的实例, 结果跟es5一样, 这个时候,我们肯定会想到person的本质是否就是一个函数呢
第7行完全验证了我们的想法,类person本质就是一个函数
第8行可以看到sayname这个函数其实还是加在person的原型对象上
第9行还是验证了es5的原型链特点:对象的隐式原型指向构造函数的原型对象
第10行验证op对象通过原型链查找到sayname方法
这种类的语法,被叫做语法糖,本质还是原型链
二、利用基本的类用法,封装一个加法运算
class operator{ constructor( n1 = 1, n2 = 2 ){ this.num1 = n1; this.num2 = n2; } add( n1 = 10, n2 = 20 ){ let num1 = n1 || this.num1, num2 = n2 || this.num2; return num1 + num2; } } var oper = new operator(); console.log( oper.add( 100, 200 ) );
三、利用基本的类语法,封装经典的选项卡
css代码:
#tab div { width: 200px; height: 200px; border: 1px solid #000; display: none; } #tab div:nth-of-type(1) { display: block; } .active { background: yellow; }
html代码:
<div id="tab"> <input type="button" value="点我1" data-target="#div1" class="active"> <input type="button" value="点我2" data-target="#div2"> <input type="button" value="点我3" data-target="#div3"> <input type="button" value="点我4" data-target="#div4"> <div id="div1">1</div> <div id="div2">2</div> <div id="div3">3</div> <div id="div4">4</div> </div>
javascript代码:
window.onload = () => { class tab { constructor( context ) { let cxt = context || document; this.ainput = cxt.queryselectorall( "input" ); this.adiv = cxt.queryselectorall( "div" ); } bindevent(){ let targetid = null; this.ainput.foreach(( ele, index )=>{ ele.addeventlistener( "click", ()=>{ targetid = ele.dataset.target; this.switchtab( ele, targetid ); }); }); } switchtab( curbtn, curid ){ let odiv = document.queryselector( curid ); this.adiv.foreach(( ele, index )=>{ ele.style.display = 'none'; this.ainput[index].classname = ''; }); curbtn.classname = 'active'; odiv.style.display = 'block'; } } new tab( document.queryselector( "#tab" ) ).bindevent(); }
以上这篇js es6系列教程 - 新的类语法实战选项卡(详解)就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。