位置: 编程技术 - 正文

JavaScript 面向对象入门精简篇第1/2页(javascript面向对象精要)

编辑:rootadmin

封装 :javascript中创建对象的模式中,个人认为通过闭包才算的上是真正意义上的封装 ,所以首先我们先来简单介绍一下闭包,看下面这个例子:是不是很眼熟呢?没错了,这其实就是一个简单的闭包应用了。简单解释一下:上面的函数myInfo中定义的变量,在它的内嵌函数showInfo中是可访问的(这个很好理解),但是当我们把这个内嵌函数的返回引用赋值给一个变量oldFish,这个时候函数showInfo是在myInfo函数体外被调用,但是同样可以访问到定义在函数体内的变量。oh yeah! 总结一下闭包的原理吧:函数是运行在定义他们的作用域中而不是调用他们的作用域中。 其实返回一个内嵌函数也是创建闭包最常用的一种方法! 如果觉得上面的解释太抽象的话,那么我们一起重塑上面的函数,看看这样是否层次鲜明一些:上例中的编码风格是ext yui 中比较常见的,公私分明,一目了然。通过闭包,我们可以很方便的把一些不希望被外部直接访问到的东西隐藏起来,你要访问函数内定义的变量,只能通过特定的方法才可以访问的到,直接从外部访问是访问不到的,写的挺累,饶了一圈终于转回来了,封装嘛,不就是把不希望被别人看到的东西隐藏起来嘛!哈哈…… 上例如果转换成JQ 的风格的话,应该如下例所写,这样的封装模式属于门户大开型模式,里面定义的变量是可以被外部访问到的(下面的例子如果你先实例化一个对象,然后在函数外部访问对象的name或者 age属性都是可以读取到的)当然这种模式下我们可以设置一些”潜规则”,让团队开发成员明白哪些变量是私用的,通常我们人为的在私有变量和方法前加下划线”_”,标识警戒讯号!从而实现”封装”! 可能有人会问,哪种模式好呢?这个怎么说呢?两种方式都有优缺点,结合着用呗!总之一个原则,一定一定不能直接被外部对象访问的东西,就用闭包封装吧。”一定一定”四个字很深奥,不断实践中才能体会真谛!

继承 :提到这个的时候,要顺便再补充一句:闭包封装中的一个缺点,不利于子类的派生,所以闭包有风险,封装需谨慎!直观起见,下面例子中创建对象的方式,采用”门户大开型”模式。

在javascript中继承 一般分为三种方式:”类式继承”,”原型继承”,”掺元类”。下面简单的介绍一下三类继承方式的原理。

A.类式继承: 这个是现在主流框架中常用的继承方式,看下例:上述子类Fish中并没定义getName方法,但是子类Fish的实例对象ioldFish依然调用到了该方法,这是因为子类Fish继承了超类 Name中定义的getName方法。解释一下,这里子类Fish的prototype指到了超类的一个实例,在子类Fish中虽然没有申明 getName方法,但是根据原型链原理,会向prototype指向的上一级对象中去查找是否有该方法,如果没找到该方法,会一直搜索到最初的原型对象。这其实也就是继承的原理了。这里特别说明一下,Fish.prototype.constructor = Fish;这句,由于默认子类的prototype应该是指向本身的,但是之前把prototype指向到了超类的实例对象,所以在这里要把它设置回来。当然这里可以把相关代码通过一个函数来组织起来,起到伪装extend的作用 B.原型继承 ,从内存性能上看优于类式继承。

很明显,原型继承核心就是这个clone函数,同样是原型链的原理,不同的是它直接克隆超类,这样的话子类就继承了超类的所有属性和方法.特别说一下,这类继承并不需要创建构造函数,只需要创建一个对象字变量,定义相应的属性和方法,然后在子类中只需要通过圆点”.”符号来引用属性和方法就可以了.

推荐整理分享JavaScript 面向对象入门精简篇第1/2页(javascript面向对象精要),希望有所帮助,仅作参考,欢迎阅读内容。

JavaScript 面向对象入门精简篇第1/2页(javascript面向对象精要)

文章相关热门搜索词:javascript面向对象编程指南第三版,javascript面向对象编程 PDF,javascript面向对象精要pdf下载,javascript面向对象编程指南,javascript面向对象精要pdf,javascript面向对象编程指南,javascript面向对象编程指南,javascript面向对象编程,内容如对您有帮助,希望把文章链接给更多的朋友!

javascript 对象定义方法 简单易学 工厂模式:初级开发者可能会这样定义对象:varobj=newObject();obj.name="hero";obj.showName=function(){alert(this.name);}这里存在一个问题就是如果我们要在多个地方用obj

JAVASCRIPT THIS详解 面向对象 虽然在开始学习的时候觉得比较难,但只要理解了,用起来是非常方便和意义确定的。JavaScript也提供了这个this关键字,不过用起来就比经典OO语言中要"

用JavaScript实现单继承和多继承的简单方法 JavaScript就其本质是函数式编程语言,是Lisp的后代,同时又加入了一下面向对象编程的元素,放弃了一些难懂的函数式语言的元素。函数式编程语言可以

标签: javascript面向对象精要

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

上一篇:JavaScript RegExp方法获取地址栏参数(面向对象)(js register)

下一篇:javascript 对象定义方法 简单易学(javascript对象定义)

  • 税务一证通
  • 受托代销商品款和受托代销商品的区别
  • 食堂费用没有发票可以税前扣除吗
  • 资本公积可以随时撤出来吗
  • 报关时电子口岸电子委托应该什么时候做
  • 一个人可以在多家公司任职吗
  • 事业单位合并财务交接
  • 设备维修劳务费税率
  • 装饰行业可否用石灰代替
  • 固定资产出售增值税税率
  • 其他公司归还货款会计分录
  • 结转已到期未兑付怎么办
  • 软件分几次开票怎么入账
  • 收到外国的货款会计分录
  • 待摊费用的金额
  • 试车要给钱吗
  • 企业对无法收回的应收账款应借记的会计科目是
  • 食堂固定资产折旧年限
  • 研发准备金期末余额帐务处理是怎样的?
  • 基本医疗保险是什么?
  • 基本户发工资要交社保吗
  • 小型微利企业所得税减免政策
  • 二甲醚增值税税率9%
  • 企业出租收入增值税税率
  • 公司注销增值税在借方有余额怎么处理
  • 应收账款手工核算方法
  • 买卖不破租赁什么情况必须搬走
  • 劳务派遣 税务
  • 工商年报人数是12月人数吗
  • 应届生能参考注册公司吗
  • 春天里的____作文
  • 质量扣款入什么科目
  • php生成二维码
  • 黄金税收多少
  • 跨省不动产登记
  • A Loepa oberthuri moth (© Robert Thompson/Minden Pictures)
  • es6promise的理解
  • 一文速学-XGBoost模型算法原理以及实现+Python项目实战
  • vue里的for循环
  • vue父子组件如何传递数据
  • ci框架视频教程
  • 去年的普票可以开红字吗
  • 采购国产设备退税公告
  • 企业所得税预缴纳税申报表
  • 损益表填制
  • 网上变更财务负责人新负责人要确认吗
  • SqlServer2012中First_Value函数简单分析
  • 准则规定的内容是
  • 存货的期末余额是账面余额吗
  • 购买软件多少钱进无形资产
  • 手机里面的发票怎么查
  • 在软件中的操作有哪些
  • 公司购买股东的东西
  • 推迟确认收入的分析
  • 固定资产折旧提头不提尾
  • 库存商品什么时候确认收入
  • 空调购买攻略
  • 企业如果为员工缴纳社保
  • 无形资产自行开发
  • 转账支票的特点有哪些
  • 自产自销农产品免税备案取消
  • 无形资产的费用化支出计入成本吗
  • 成本核算的意义在于
  • ubuntu安装超详细教程
  • ubuntu14升级
  • 安装win 7系统
  • uup windows
  • windows7无法关闭密码保护共享
  • 注册表 windows
  • unity特效制作教程
  • ai控制器的简称是
  • OpenGl的glMatrixMode()函数理解
  • node.js安装教程详细
  • linux系统tomcat启动
  • parentElement,srcElement的使用小结
  • 运算符优先级由高到低的顺序
  • 利用python中的运算符可以编程解决你身边的哪些问题
  • 编写python程序的步骤
  • jquery 菜单
  • 税务罚款会影响宝宝当公务员不
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设