位置: 编程技术 - 正文

面向对象的编程思想在javascript中的运用上部(面向对象的编程语言更适合大规模编程)

编辑:rootadmin
其实,面向对象的思想是独立于编程语言的,例如在C#中,在一个静态类的静态方法中,按照过程式开发调用一系列静态函数,我们很难说这是面向对象的编程,相反,象jquery和extjs这样优秀的javascript库,却处处体现着面向对象的设计思想。本文不打算探讨javascript是否能够算做面向对象的编程语言,这个问题是重视中国式考试的人应该关注的,我这里只是简单的说明如何在javascript中使用面向对象的编程思想。 面向对象首先要有对象。在javascript中创建一个对象非常简单: 这样就产生了一个对象,我们可以很方便的给这个对象添加属性和方法: 不过大多数人还是习惯把对象的属性和方法放在定义对象的一对{}里边: 访问属性和方法有两种方式,第一种: 这种写法很常见,C#中调用对象的属性和方法也是这种方式。还有一种是javascript中比较特别的,使用属性或者方法的名字作为索引来进行访问: 这好像有点和孔乙己“茴香的茴字有几种写法”差不多了,事实上,很少有人使用索引来调用对象的属性或者方法。 除了我们自定义的属性和方法,我们的对象还有一个constructor属性以及toString()等方法。这些属性和方法是从Object内置对象来的,所有的对象都会有这些属性和方法。其中constructor属性指向构造出该对象的构造函数。我们没有使用构造函数来创建对象,事实上,js的解释器会使用Object构造函数。如果我们自己定义了构造函数,那么便可以通过该构造函数来创建对象,这样可以使得创建的对象具有相同的属性和方法,这便开始有点面向对象的味道了。好,我们从一个简单的例子开始看看如何创建一个构造函数吧: 我们定义了一个名字叫Person的构造函数,该构造函数有三个属性和一个方法,通过构造函数来产生一个对象并调用方法也非常简单: 运行后我们可以看到弹出一个对话框,显示出这个叫张三的人的信息: 我们还可以看看对象的constructor属性来看看zhangsan的构造函数是不是我们定义好的Person: 结果如图: 可以看到,正是我们的Person构造函数。 不过,这里还是有点问题,每一次我们构造一个对象,都会在内存中为属性和方法分配内存空间,而事实上,所有的对象完全可以用同一个方法,并不需要有多个方法的副本,这样有些浪费内存空间。既然意识到了这个问题,让我们来想想如何解决吧。一个很自然的想法是,既然我们只想为方法分配一次内存空间,那么我们可以设置一个值用来标识方法的内存空间是否已经分配,按照这个思路,我们将构造函数做如下修改: 这里,我们用一个成员_initialized来指示是否已经对方法进行了内存空间的分配。当第一个对象构造的时候_initialized未被定义,所以我们的判断语句为真,这时会对方法进行了定义并分配内存空间,然后把_initialized的值设置为true,用以表明方法的内存空间已经分配了。第二个对象构造的时候则不会再进入判断,因而也不会再一次分配内存空间。似乎没什么问题,运行一下看看,张三的信息依然正常显示。虽然不辛苦,不过解决了一个小问题,还是庆祝下吧,来盘回锅肉,我要大快朵颐。还没开吃,一个叫李四的MM也想让电脑弹出她的个人信息。OK,很简单,再构造一个对象,然后调用showInfo方法就可以了: 为了照顾MM,还把这段放在了张三的前边。MM的信息正确显示出来了,可是张三的资料不见了。这下张三不乐意了,排名放在MM后边也罢了,但好歹得有名字啊。这可苦了我这编程人员,回锅肉看来没办法吃了,先改bug吧。打开firebug,看到MM的信息显示之后出现错误,提示为:zhangsan.showInfo is not a function。设置断点看看,构造zhangsi对象以后发现并没有showInfo这个方法。原来showInfo方法虽然只有一个,但是存在于第一个对象之中,第二个对象并不能访问。那么,究竟如何才能让同一个构造函数产生的对象共用同一个函数呢?javascript中的prototype给我们提供了这个功能。根据javascript的规范中描述,每一个构造函数都有一个prototype属性用于实现继承和属性的共享。我们的showInfo方法也可以看作是一个属性,该属性指向一个函数的引用。现在我们使用prototype来使得我们的方法可以共享,代码的改动很简单,把this.showInfo改成Person.prototype.showInfo就可以了,改动之后的代码如下: 使用该构造函数生成两个对象: 运行之后先显示李四的信息,然后是张三的信息。现在两个人都满意了,可惜我的回锅肉已经凉了

推荐整理分享面向对象的编程思想在javascript中的运用上部(面向对象的编程语言更适合大规模编程),希望有所帮助,仅作参考,欢迎阅读内容。

面向对象的编程思想在javascript中的运用上部(面向对象的编程语言更适合大规模编程)

文章相关热门搜索词:面向对象的编程方法的英文缩写是,面向对象的编程语言有哪些,面向对象的编程方法,面向对象的编程方法,面向对象的编程方法的英文缩写是,面向对象的编程思路,面向对象的编程思路,面向对象的编程思路,内容如对您有帮助,希望把文章链接给更多的朋友!

JS小框架 fly javascript framework 框架选择器部分兼容浏览器原生的查询语法,和jQuery大部分选择器,选择器部分文档大部分来自jQeruyAPI特点,选择器支持lambda表达式文件打包下载

JS类的封装及实现代码 1.定义js类js并不是一种面向对向的语言,没有提供对类的支持,因此我们不能像在传统的语言里那样用class来定义类,但我们可以利用js的闭包封装机制来实

javascript 面向对象全新理练之数据的封装 今天主要讨论如何在JavaScript脚本中实现数据的封装(encapsulation)。数据封装说的简单点就是把不希望调用者看见的内容隐藏起来。它是面向对象程序设

标签: 面向对象的编程语言更适合大规模编程

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

上一篇:Riot.js 快速的JavaScript单元测试框架(java script js)

下一篇:JS小框架 fly javascript framework(js框架开发实例)

  • 6.72的税率是怎么算的
  • 某煤矿将自采原煤用于投资的业务应缴纳资源税
  • 开具增值税发票未报送是什么意思?
  • 中国注册税务师考试时间
  • 防疫物资采购计入什么费用
  • 开增值税发票规格是否可以不用填
  • 税控系统的清单
  • 已付的账款叫什么
  • 个人购买商铺如何缴税
  • 异地存货管理
  • 行政单位应缴财政收入预算会计分录
  • 非货币性资产交换的记忆口诀
  • 农民合作社缴附加税吗
  • 盘亏存货需要进项税额转出吗
  • 银行收付款通知短信
  • 税目与应纳税额的关系
  • 电商公司怎么进入
  • 雇主责任险可以税前扣除吗
  • 个人从上市公司取得的分红个税怎么申报
  • 减税降费政策六税
  • 出纳可以做记账表格吗
  • 个税返还增值税申报表填哪里
  • 库存占销售的多少合适
  • 销售费用核算原则
  • 销售净利率计算公式是什么
  • 1697509300
  • 股东房产无偿给公司使用协议
  • 五险一金的记账凭证怎么填写
  • mac big sur 新功能
  • thinkphp表单提交
  • 出售固定资产增值税怎么处理
  • 转销盘盈会计分录
  • 资产负债表的编制方法和步骤
  • 图像相似性度量
  • 1558伊丽莎白女王
  • 资产负债表中其他综合收益怎么填
  • 发票抬头可以是两个人吗
  • vue 使用js
  • 发票过账和不过账是什么意思
  • 初级农产品免税普票能否抵扣
  • pytorch1.9.0
  • php+mongodb
  • 媒体查询是什么
  • thinkphp withjoin
  • ps去水印的三种方法
  • php中array用法
  • 残保金工资标准
  • 增值税普通发票怎么开
  • 免抵退申报汇总表在哪里
  • 预收账款开票了怎么做账报税
  • 现金流量表和资产负债表的区别
  • vue3.0用法
  • 产权转移数据印花税纳税期限
  • 企业车辆年检费多少钱
  • 财务报表怎么重新编制
  • 进项抵扣了还要交附加嘛
  • 增值税中进项税额转出是什么意思
  • 请培训老师的费用怎么处理
  • 应交增值税为负数是什么意思
  • 应收票据周转率公式
  • 银行结息交易是扣钱的意思吗
  • 扶贫入股分红政策
  • 普通发票作废的金额会扣税吗
  • 企业持有的能够对被投资单位实施控制的长期股权投资
  • sql server高级应用
  • 如何查看windows
  • winxp系统停止服务
  • win7系统如何隐藏任务栏
  • centos配置kdump
  • Ubuntu系统怎么设置root
  • xp系统怎么打开开机启动项
  • javascript标准
  • PyCharm在win10的64位系统安装实例
  • Node.js中的核心模块包括哪些内容?
  • jquery显示图片
  • jquery动态添加属性
  • jquery的循环
  • 说一说我下乡插队时的那点事
  • 深圳城管局 局长
  • 北京地税app
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设