位置: 编程技术 - 正文

Javascript 中的类和闭包(js中的类和对象)

编辑:rootadmin
有人说javascript也是面向对象的,只是它是prototype based,当然这只是概念上的区别,我不想讨论js是不是面向对象的,关键是想说明虽然javascript的类表现得很像其他语言中的类,但是内部的实现机理确不太一致,如果一味的把javascript中的类类比作其他语言中的类,有时候脑子会犯混。 先看一段简单的代码,一般教材上介绍如何新建一个类的时候都是这样的(当然还有更复杂的方法,不过本质上是一样的): 毫无疑问,此时obj具有一个x属性,现在的值是 Hello class. 但是,obj到底是什么?MyClass仅仅是一个函数而已,我们称之为构造函数。在其他OO的语言中,构造函数是要放在class关键字内部的,也就是先要声明一个类。另外,函数体内的this又是什么?其他OO语言中,this的概念是很明确的,就是当前对象,因为它在构造函数执行之前已经声明了类,类的内部的一些字段都是已经定义好的。 先解释下,在javascript的函数中,this关键字表示的是调用该函数的作用域(scope),作用域的概念也不是太好理解,下面再解释。不过可以简单的认为它是调用函数的对象。再看MyClass函数,它内部的this是什么呢? 如果我们把代码改成: 这是完全合乎语法的。如果这段代码是在浏览器中运行的,调试一下可以发现,this是window对象。而和obj没有任何关系,obj还是undefined,alert也不会有结果。原来的代码之所以可以工作,都是new关键字的功劳。new关键字把一个普通的函数变成了构造函数。也就是说,MyClass还是一个普通的函数,它之所以能构造出一个obj,基本上是new的功劳。当函数之前有new关键字的时候,javascript会创造一个匿名对象,并且把当前函数的作用域设置为这个匿名对象。然后在那个函数内部引用this的话就是引用的这个匿名对象,最后,即使这个函数没有return,它也会把这个匿名对象返回出去。那么obj自然就具有了x属性。 现在这个MyClass已经有点像一个类了。但是,这并不是new的工作的全部。Javascript同样可以方便的实现继承——依靠是prototype.prototype也是一个对象,毕竟除了原始类型,所有的东西都是对象,包括函数。更为重要的是,前面提到javascript是prototype based,它的含义就是在javascript中没有类的概念,类是不存在的,一个函数,它之所以表现的像类,就是靠的prototype. prototype可以有各种属性,也包括函数。上一段说的new在构造对象的过程中,在最终返回那个匿名对象之前,还会把那个函数的prototype中的属性一一复制给这个对象。这里的复制是复制的引用,而不是新建的一个对象,把内容复制过来,在其内部,相当于保留了一个构造它的函数的prototype的引用。有些教材含糊的说所有的“所有对象都有一个prototype属性”,这种说法是不确切的,虽然它内部确实有一个prototype属性,但是对外是不可见的。只有函数对象是有prototype属性的,函数对象的prototype默认有一个constructor属性。 看如下的代码: 输出的结果是changed和Changed Too。此代码说明了对象内部保留的是构造函数的prototype的引用,要注意的是,proObj中也是保留的它的构造函数的prototype的引用。如果把代码改成: 输出的就是 I am winner 和 Changed Too了。事实上,这些prototype逐层引用,构成了一个prototype链。当读取一个对象的属性的时候,首先寻找自己定义的属性,如果没有,就逐层向内部隐含的prototype属性寻找。但是在写属性的时候,就会把它的引用覆盖掉,是不会影响prototype的值的。 再介绍闭包,首先说明下,这里的闭包(closure)和离散数学中关系的传递闭包中的不是一个概念,我曾以为他们之间有关联,后来仔细想想,似乎并无什么关联,恰好名字一样而已。先看定义: Closure A "closure" is an expression (typically a function) that can have free variables together with an environment that binds those variables (that "closes" the expression). 要完全理解闭包需要对Javascript函数的机理有比较透彻的理解,而这个机理有点复杂,并不是三言两语能讲清的,有兴趣的朋友可以看这里 Javascript clousures. 即使是这篇文章,也只是大概讲了下原理。大意就是任何一个函数调用都在一个运行上下文(Execution Context)中执行的,这个上下文中有一个作用域对象,其中包括了这个函数的局部变量、参数等。另外,如果一个函数是一个内部函数,它的作用域中含有它外部函数的作用域。在内部函数遇到一个变量名的时候,它是从内部的作用域找起,不断往外层的作用域找。因此,如果内部函数作为一个对象返回出外部函数的时候,即使外部函数已经执行完毕,但是由于其内部函数仍有引用指向它,内部函数不会被释放,因为内部函数有外部函数的作用域,因此外部函数的局部变量也不会被释放。这就构成了闭包。

推荐整理分享Javascript 中的类和闭包(js中的类和对象),希望有所帮助,仅作参考,欢迎阅读内容。

Javascript 中的类和闭包(js中的类和对象)

文章相关热门搜索词:js中类的定义,javascript class类,js里面的类,js中类的定义,js里面的类,js中类的定义,javascript中的类型转换,js里面的类,内容如对您有帮助,希望把文章链接给更多的朋友!

JS 对象介绍 JavaScriptisanObjectOrientedProgramming(OOP)language.JS是面向对象的编程语言(面向对象)。(这里是基于对象还是面向对象大家可以搜索下)AnOOPlanguageallowsyoutodefi

JavaScript 使用简略语法创建对象的代码 JavaScript使用简略语法创建对象[Ctrl+A全选注:如需引入外部Js需刷新才能执行]

javascript面向对象的方式实现的弹出层效果代码 说到js的面向对象,就不得不提到prototype这个js内置属性了(注意:这里的prototype可不是prototype.js),它的作用就是可以动态的向一个对象(object)添加某种属

标签: js中的类和对象

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

上一篇:javascript new一个对象的实质(js中new一个函数)

下一篇:JS 对象介绍(js对象的常用方法)

  • 税前扣除的项目包括
  • 会计所得税公式怎么算
  • 预包装食品销售流程图
  • 个体户开票超过500万能注销吗
  • 7月薪资8月发怎么交税
  • 重型开输机属于固定资产什么类别
  • 残保基金的计算公式
  • 小微企业的增值税怎么算
  • 企业怎样才能做好信用信息修复?
  • 个人转让著作权所得免征个人所得税吗
  • 水利建设工程
  • 公司房产税如何征收税率
  • 外贸企业留抵税额过大
  • 购销合同印花税怎么算
  • 预缴的企业所得税可以扣除吗
  • 出口退税的办理影响出口吗
  • 税控系统技术维护费抵扣如何填报
  • 行政事业单位2014年前已交社保费
  • 逃避的概念
  • 出租车发票有出租车信息吗
  • 劳务工资要附什么合同
  • 企业报税表
  • 1697510472
  • 在建工程产生废料收入的账务处理?
  • 苹果中国区副总裁
  • u盘中病毒了怎么格式化
  • 保税区开出的专票可以抵扣吗
  • 小型微利企业免税政策
  • 购买保本理财产品
  • 独生子女父母有意外险吗
  • 附有退货权商品是什么
  • 预提收入的会计处理方法
  • 财政补助收入的支付制度包括
  • 支持h5浏览器
  • 增值税的优惠有哪三种形式
  • php面向对象的理解
  • yolov5结构解析
  • 命令提示符用不了怎么办
  • vue脚手架配合springsecurity
  • 如何构建自己的精神空间
  • js防抖节流的区别和使用场景
  • 应收账款未计提怎么处理
  • 结转已销产品计入什么科目
  • 应交税费中印花税是什么
  • phpcms建站流程
  • python mad
  • 学网新用什么电脑
  • mongo聚合查询效率问题
  • Python psd-tools如何转换文件
  • 私募基金成立备案流程
  • 定金罚则可以约定吗
  • 企业所得税的营业收入包括营业外收入吗
  • 根据工资总额组成的规定下列哪些列入工资总额的范围
  • 记账错误是什么意思
  • 三证合一哪三个证
  • 货物出去没有出口报关可以补吗
  • 建筑工程拨款申请模板
  • 买断式买入
  • 外派人员房租
  • 商业批发是什么意思
  • unix系统中目录采用什么结构
  • ubuntu :wq
  • U盘硬装WIN7 64位旗舰系统,是怎样练成的(妹子装机衔接篇)
  • asm是啥
  • win7z
  • msvcmm32.exe - msvcmm32是什么进程 有什么用
  • Win10年度升级版将正式提供暗黑主题 未自定义颜色都会变暗
  • activex控件在哪设置
  • unity怎么新建项目
  • jquery渐变效果
  • java的file类的常用操作
  • angularjs常用总结
  • 基于jQuery的AJAX和JSON实现纯html数据模板
  • python作用域和优先级
  • python 时间戳与格式化时间的转化实现代码
  • 酒店住宿的发票图片
  • 电子税务局开的发票怎么作废
  • 丰台和朝阳中间是哪里
  • 浙江省税务局发短信是真的吗
  • 国税局辽宁省国税局
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设