位置: 编程技术 - 正文

JS面向对象(3)之Object类,静态属性,闭包,私有属性, call和apply的使用,继承的三种实现方法(js面向对象面试题)

编辑:rootadmin

推荐整理分享JS面向对象(3)之Object类,静态属性,闭包,私有属性, call和apply的使用,继承的三种实现方法(js面向对象面试题),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:js面向对象的三大特性,js面向对象的理解,js面向对象还是面向过程,js面向对象面试题,js面向对象编程实例,js面向对象还是面向过程,js面向对象面试题,js面向对象的三大特性,内容如对您有帮助,希望把文章链接给更多的朋友!

1.Object类

在JS中,Object是所有类的基类,使用Object类来创建自定义对象时,可以无需定义构造函数(constructor,prototype,hasOwnProperty(property))

我们想在程序中得到一个对象变量,只要能存储大量数据即可,这个时候,我们可以考虑使用Object类。Object类避免了对构造器的定义。 Object类下另一个常用的属性:hasOwnProperty

2.静态属性

在有些面向对象的语言当中,可以使用static关键字定义类的静态属性或者静态方法,在JS中,可以进行模拟。

语法:

类名.属性名

类名.属性=function(){}

添加静态属性和静态方法:

3.闭包

概念:所谓闭包,指的是一个拥有许多变量和绑定了这些变量的环境的表达式(通常是一个函数),因此这些变量也是该表达式的一部分。

提出一个问题:

在全局中,不能访问局部变量i,因为作用域不同,而且,在display函数执行完毕后,局部变量i会被回收。 闭包的功能:“访问局部变量”和“使变量所占的内存不被释放”

通过例1我们知道:变量是可以指向函数的首地址的,函数也可以返回另一个函数的首地址。

通过例2我们知道:使用一个拒不函数包含变量i,这样局部变量i的内存不会被回收。

在例3中,因为i的内存永远不会被回收,所以每次调用fn2,i的值会+1。运行的结果是弹出,弹出,弹出。

闭包的原理:在例3中,共有三个作用域:全局作用域,fn1的作用域,fn2的作用域。在全局作用域里有test=fn1(),其实这句话就相当于test=fn2。在fn1作用域里有 var i=和return fn2,在fn2作用域例有alert(i++)。当全局作用域下的test=fn1()执行时,test指向了fn2的作用域,这个时候fn2作用域下的i被全局作用域钩住,根据作用域链的法则,fn2下并没有定义i,所以在fn2下的i往上一层作用域上找,找到了fn1作用域下的var i=。所以全局的test钩住了fn2的i,fn2的i钩住了fn1的i,所以fn1运行完毕后,不会被回收。

4.私有属性

在面向对象思想中,对于有些敏感的,不想公开的成员可以定义为私有的,在JavaScript中可以模拟这个功能。

语法:

var :私有

this :公有

在上面这个例子中,我们想用 var 来表示私有成员属性,但 Person 构造函数执行完毕后, age 会被回收,不能当做成员属性来使用。

this.setAge和this.getAge两个方法使用到了局部变量age,所以age不会被回收。

如果只有set方法,说明该属性是只写属性。

如果只有get方法,说明该属性是只读属性。

5.call和apply的使用

call和apply的功能:使用指定的对象调用当前函数。call和apply的功能完全相同,只是在语法上略有不同。

JS面向对象(3)之Object类,静态属性,闭包,私有属性, call和apply的使用,继承的三种实现方法(js面向对象面试题)

语法:

call([thisObj[,arg1[,arg2[,argN]]]])

第一个参数:函数执行时,this指向谁

后面的参数:根据需要顺序指定

apply([thisObj[,argArray]])

第一个参数:函数执行时,this指向谁

第二个参数:数组,表示参数集合

在js中,函数有几种调用形式:

使用call和apply来调用

call和apply在执行时做了两件事:1)将函数内部this指向了第一个参数 2)调用函数

另外:还可以这样解决问题:

P1.say=speak;

P1.say();

这样解决和上面解决方法有本质上的区别:

上面的解决办法是直接调用speak函数,只不过函数内部this的指向发生改变。

下面的解决办法会为p1对象增加属性,p1对象的“体积”会变大。

举例说明:

6.继承的三种实现方法

概念:在有些面向对象语言中,可以使用一个类(子类)继承另一个类(父类),子类可以拥有父类的属性和方法,这个功能可以在js中进行模拟。

三种方法:

第一种:扩展Object方法

举例说明:

第二种:使用call和apply方法

语法:

父类构造器.call(this,.......);

第三种:原型继承

语法:

子类.prototype = new 父类();

以上内容给大家介绍了JS面向对象(3)之Object类,静态属性,闭包,私有属性, call和apply的使用,继承的三种实现方法,希望对大家有所帮助!

js判断图片加载完成后获取图片实际宽高的方法 本文实例讲述了js判断图片加载完成后获取图片实际宽高的方法。分享给大家供大家参考,具体如下:通常,我们会用jq的.width()/.height()方法获取图片的

JavaScript实现搜索框的自动完成功能(一) 在很多需要搜索的网站,都会有一个自动完成的搜索框.方便用户查找他们想要的搜索词.帮助用户快速找到自己想要的结果.这种方式是比较友好的.所以是

灵活的理解JavaScript中的this指向 this是JavaScript中的关键字之一,在编写程序的时候经常会用到,正确的理解和使用关键字this尤为重要。首先必须要说的是,this的指向在函数定义的时候

标签: js面向对象面试题

本文链接地址:https://www.jiuchutong.com/biancheng/380355.html 转载请保留说明!

上一篇:JavaScript代码因逗号不规范导致IE不兼容的问题(js代码不生效)

下一篇:深入php面向对象、模式与实践(深入php面向对象、模式与实践第5版 电子书)

  • 长期股权投资的入账价值怎么算
  • 工资薪金和工资薪金总额区别
  • 小规模企业税收优惠政策2023
  • 什么是税务代理人
  • 进项认证以后如何开具红字信息表
  • 增值税留抵税额是什么意思
  • 药品费用开具增值税发票项目应为什么
  • 可辨认净资产和所有者权益的区别
  • 退回以前年度的增值税账务处理
  • 赠品的会计核算内容
  • 动漫版权交易
  • 装饰行业可否用石灰代替
  • 以旧换新销售货物的增值税处理
  • 制造费用可以抵进项税吗
  • 报价需要提供哪些资料
  • 股票价格变化的原因
  • 房产税征收范围包括商铺吗
  • 绩效奖金是否属于工资判决书
  • 怎么把过期银行卡的钱取出来
  • 业务招待费不超过销售收入的5‰
  • 长期未收回的应收账款企业所得税
  • 事业单位财政拨款是什么意思
  • 私立幼儿园收费归哪个部门管
  • 税额差异会计分录
  • wamp搭建网站教程
  • Laravle eloquent 多对多模型关联实例详解
  • linux 数字加减
  • php字符串型数据的定义方式
  • 其他应付款的会计分录怎么写
  • excel2019冻结
  • 代开发票要带什么资料去税务局办理?
  • 居民企业境外所得税抵免限额
  • 小程序常见问题
  • 破产企业发放工资怎么算
  • 房地产企业借款可以用未建成的房子设定浮动抵押吗?
  • 农产品抵扣进项税额的规定
  • 低值易耗品报废年限几年
  • opencv训练模型教程
  • 【机器学习】KNN算法及K值的选取
  • linux 静态链接
  • hashmap教程
  • 库存盘点差异分录
  • 累计折旧当月增加当月减少
  • 帝国cms配置数据库
  • phpcms生成html
  • 玉米 收购
  • 免税不能抵扣
  • 小型微利企业的认定标准2023年
  • 销售包括是销项税金吗
  • 甲供工程范围
  • 汇算清缴 房租
  • 定期定额户超过9万如何交个税
  • 拒收发票需要拒收证明么
  • 小规模纳税人去银行开立什么账户
  • 无形资产入账
  • 解除合同补偿金需要缴纳个税吗
  • 认缴款和投资款区别
  • 文化事业建设费逾期未申报怎么办
  • 会计凭证装订时间法律规定
  • 延期支票可以撤回吗
  • 什么是盈亏平衡法
  • sql server的mdf文件怎么导入数据库
  • cmos开机密码的清除的二种方法
  • server.exe是什么
  • centos下载安装
  • win10注册表的作用
  • cocos 2d x
  • vs2019创建安装程序
  • JavaScript事件处理的方式(三种)
  • javascript怎么做
  • js特殊字符有哪些
  • 修改应用程序图标
  • 出租车票如何验真
  • 河南电子税务局开票流程
  • 成都市地方税务局 组织税收收入 2010
  • 地方公安局归谁管
  • 耕地占用税 税额
  • 沈阳税务局营业时间查询
  • 专用发票收款人可以盖私章吗
  • 2022年广州社保基数
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设