位置: 编程技术 - 正文

面向对象的编程思想在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框架开发实例)

  • 缴纳增值税做账
  • 关联公司往来款算应收账款吗
  • 一次性支付一年房租怎么做账每月如何结转
  • 机械设备租赁印花税谁交
  • 预付账款怎么处理
  • 个税个人减免
  • 公司员工的伙食费计入什么科目
  • 成本暂估跨年度要怎么处理?
  • 2021虚开发票案例
  • 已验旧和未验旧
  • 个人之间的房屋抵押需要去房管局做登记吗
  • 股权转让收益算利润吗
  • 购买国债兑现时要交税吗
  • 技术服务费进项票会计分录
  • 固定资产折旧计算方法
  • 实物出资需要发票吗
  • 稿费个人所得税计算方式
  • 电脑休眠和睡眠什么差别
  • 文件类型有几种分类
  • 债权债务重组公司
  • PHP:xml_parser_set_option()的用法_XML解析器函数
  • PHP:Memcached::getMultiByKey()的用法_Memcached类
  • 股票期权行权的基本每股收益怎么算
  • uniapp自定义组件模式
  • 在建工程可以计入资本性支出吗
  • 主营业务收入含义
  • 正常损失非正常损失
  • 外币借款费用
  • 生产型企业出口退税计算案例
  • css 宽度 自适应 占满
  • vue路由使用方法
  • echarts简介
  • 读懂spring源码
  • sql server2016使用
  • vue模块拖拽
  • web系统的安全现状
  • lvm 命令
  • js删除
  • php使用oci8扩展连接oracle
  • vue elementui table
  • phpcms插件
  • mysql的字符串
  • 小型微利企业的认定标准2023年
  • 房地产企业所得税预缴毛利率
  • 个体户也需要纳税吗
  • 实收资本实务处理办法
  • 工业企业外购存货的实际成本不包括
  • 生产企业支付的房租怎么入账
  • 收银系统入库入错了怎么办
  • 医院收费票据可以入账吗
  • 员工拿发票报销怎么做账
  • 新成立的公司开什么银行账户
  • 促销服务属于什么服务按什么征增值税
  • sql server?
  • win8.1关机没反应
  • 使用二氧化碳灭火器时人应该站在什么位置
  • unix系统采用什么结构
  • u盘安装win8系统教程图解
  • 鼠标点击关闭按钮没反应
  • linux vi命令详解菜鸟教学
  • Ubuntu如何安装vim编辑器
  • win8系统怎么到桌面
  • win10 屏幕键盘
  • win8更改电脑设置在哪
  • linux升级内核要重启吗
  • android开发环境搭建实验报告总结
  • nodejs实战教程
  • opengl使用教程
  • js中的三种弹出式消息提醒的命令是什么
  • CalledFromWrongThreadException: Only the original thread that created a view
  • unity3d移动物体
  • 详解linux设备
  • android入门视频教程
  • 编写javascript代码
  • python 打印对象的全部属性
  • jquery实现图片横向移动
  • 深圳税务 qzzn
  • 房屋租赁税率是6还是9
  • 深圳个体户不注销的后果
  • 金税盘白盘如何换纽扣电池
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设