简述JavaScript的类与对象
2024-08-02 10:39:57 218人阅读
JavaScript语言是动态类型的语言,基于对象并由事件驱动。用面向对象的思想来看,它也有类的概念。JavaScript 没有class关键字,就是用function来实现。
1. 实现方式及变量/方法访问域控制
1 | function fruit(name, color) |
用this来标识变量或方法是public。兴城市费永礼品
1 | var apple = new fruit( ‘apple‘ , ‘red‘ ); |
跟其他大多数语言一样是用 new 关键字来实例化一个类的对象。这样 apple.name 的值就是 ‘apple‘。内部变量则使用var关键字:
3 | var subject = "welcome to nowamagic.net" ; |
这个时候访问b1.subject,得到的结果是"undefined"。
2. 类的扩展
JavaScript是动态语言,因此我们可以在类创建之后再给他添加属性(field)或方法。具体做法就是使用prototype:
01 | function fruit(name, color) |
07 | var apple = new fruit( ‘apple‘ , ‘red‘ ); |
08 | var orange = new fruit( ‘orange‘ , ‘yellow‘ ); |
10 | fruit.prototype.gender=1; |
可以看到变量apple, orange都有了gender的属性,且值为1。
也有人把prototype扩展的内容称之为静态方法或属性,我认为这样称呼有些不太合适,因为静态的内容是不能通过对象来访问的,这里则可以,且如果更改apple.gender,不会影响orange.gender的值。另一个理由这里的gender不能像其他语言的静态属性一样直接是用类名来访问:
只能这样:
3. 对象与数组的关系
3 | tom[ ‘Email‘ ]= ‘qq@qq.com‘ ; |
5 | tom.Website= "www.nowamagic.net" ; |
由此可以见对象的field可以通过数组的方式访问,反之亦然。使用field的方式访问,从风格上讲更像面向对象的风格,但是是用数组方位在某些遍历对象的时候很是方便。
简述JavaScript的类与对象
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉:
投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。