jses6中新的类语法选项卡是怎样的
发表于:2025-02-02 作者:千家信息网编辑
千家信息网最后更新 2025年02月02日,这篇文章将为大家详细讲解有关jses6中新的类语法选项卡是怎样的,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。其实es6的面向对象很多原理和机制还是E
千家信息网最后更新 2025年02月02日jses6中新的类语法选项卡是怎样的
这篇文章将为大家详细讲解有关jses6中新的类语法选项卡是怎样的,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。
其实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代码:
1234
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(); }
关于jses6中新的类语法选项卡是怎样的就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。
语法
对象
原型
函数
还是
就是
本质
代码
实例
封装
验证
中新
内容
文章
方法
时候
更多
知识
篇文章
不错
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
数据库分离怎么还原
小学网络安全宣传周手抄报
昆仑云服务器是什么
软件开发公司支付的认证费用
sql怎么看服务器是否内存不足
西门子1200pct服务器
公安网络安全应急工作
苏州智壳互联网科技有限公司
数据库系统采用的安全措施
免费下载网络安全psd素材
数据库理论基础学生课堂笔记
网络安全法中的三个保护
广州所有软件开发微信开发
modbus主站服务器
耒阳软件开发中职学校
太仓正规软件开发公司
基础设施与网络安全招聘
贵州省中小学网络安全答题
杨浦区媒体数据库服务销售价格
政府单位计算机网络安全
什么样的网络适合做服务器
异常行为分析 数据库
数据库-501
伊犁软件开发服务介绍
c 数据库联合查询系统
神奇屋网络技术服务
计算机二级网络技术难度
e3 1231 v3是服务器吗
汽车业网络安全有新突破
医学excel数据库