位置: 编程技术 - 正文

JavaScript定义类或函数的几种方式小结(javascript定义数组的方法)

编辑:rootadmin
提起面向对象我们就能想到类,对象,封装,继承,多态。在《javaScript高级程序设计》(人民邮电出版社,曹力、张欣译。英文名字是:Professional JavaScript for Web Developers)这本书中描述的还算比较详细。我们看看JavaScript中定义类的各种方法。 1.工厂方式 javaScript中创建自己的类和对象,我们应该是必须掌握的,我们都知道javaScript中对象的属性可以在对象创建后动态定义,比如下面的代码: 我们很容易使用oCar对象,但是我们创就是想创建多个Car实例。我们可以使用一个函数来封装上面的代码来实现:<script type="text/javascript"> 顺便说一下,javaScript对象默认成员属性都是public 的。这种方式我们称为工厂方式,我们创造了能创建并返回特定类型的对象的工厂。 这样做有点意思了,但是在面向对象中我们经常使用创建对象的方法是: Car car=new Car(); 使用new 关键字已经深入人心,因此我们使用上面的方法去定义总感觉别扭,并且每次调用时都去创建新的属性以及函数,功能上也不实际。下来我们看看构造函数的形式定义类。 2.构造函数 这种方式看起来有点象工厂函数。具体表现如下: 看起来效果很明显,有差别了吧。感觉有点意思了。在构造函数内部创造对象使用this 关键字,使用new 运算符创建对象感觉非常亲切。但是也有点问题:每次new 对象时都会创建所有的属性,包括函数的创建,也就是说多个对象完全独立,我们定义类的目的就是为了共享方法以及数据,但是car1对象与car2对象都是各自独立的属性与函数,最起码我们应该共享方法。这就是原形方式的优势所在。 3.原型方式 利用对象的prototype属性,可把它看出创建新对象所依赖的原型。方法如下: 首先这段代码的构造函数,其中没有任何代码,接下来通过对象的prototype属性添加属性定义Car对象的属性。这种方法很好,但是问题是Car的对象指向的是Array指针,Car的两个对象都指向同一个Array数组,其中一个对象car1改变属性对象的引用(数组Array)时,另一个对象car2也同时改变,这是不允许的。 同时该问题也表现在原型不能带任何初始化参数,导致构造函数无法正常初始化。这需要另一种方式来解决:那就是混合的构造函数/原型模式。 4. 混合的构造函数/原型模式 联合使用构造函数和原型方式,定义类就非常方便。 该方法是把属性放在内部定义,把方法放在外边利用prototype进行定义。解决了第三种方法的问题。 这种方法其实应该来说非常友好了,但是比起java的语法来,应该有一些不和谐,感觉比较凌乱,对C++来说,我们就没有那么麻烦的感觉了,可是开发C++的研发人员一般情况下很少涉及javaScript,而对J2EE的研发人员来说,这种方式总有一些别扭。总感觉不是友好的封装,其实只不过是视觉上封装效果不是很好而已,要想达到视觉封装效果而又能达到这种方法的效果的也可以以,个人认为其实比较麻烦。那就是动态原型法。 5.动态原型 对于习惯使用其他语言的开发者来说,使用混合的构造函数/原型方式感觉不那么和谐。毕竟,定义类时,大多数面向对象语言都对属性和方法进行了视觉上的封装。考虑下面的C#类: C#很好的打包了Car类的所有属性和方法,因此看见这段代码就知道它要实现什么功能,它定义了一个对象的信息。批评混合的构造函数/原型方式的人认为,在构造函数内存找属性,在其外部找方法的做法不合逻辑。因此,他们设计了动态原型方法,以提供更友好的编码风格。 动态原型方法的基本想法与混合的构造函数/原型方式相同,即在构造函数内定义非函数属性,而函数属性则利用原型属性定义。唯一的区别是赋予对象方法的位置。下面是用动态原型方法重写的Car类: 直到检查typeof Car._initialized是否等于"undefined"之前,这个构造函数都未发生变化。这行代码是动态原型方法中最重要的部分。如果这个值未定义,构造函数将用原型方式继续定义对象的方法,然后把Car._initialized设置为true。如果这个值定义了(它的值为true时,typeof的值为Boolean),那么就不再创建该方法。简而言之,该方法使用标志(_initialized)来判断是否已给原型赋予了任何方法。该方法只创建并赋值一次,为取悦传统的OOP开发者,这段代码看起来更像其他语言中的类定义了。 6 混合工厂方式 这种方式通常是在不能应用前一种方式时的变通方法。它的目的是创建假构造函数,只返回另一种对象的新实例。这段代码看来与工厂函数非常相似: 与经典方式不同,这种方式使用new运算符,使它看起来像真正的构造函数: var oCar = new Car(); 由于在Car()构造函数内部调用了new运算符,所以将忽略第二个new运算符(位于构造函数之外)。在构造函数内部创建的对象被传递回变量var。这种方式在对象方法的内部管理方面与经典方式有着相同的问题。强烈建议:除非万不得已(请参阅第章),还是避免使用这种方式。 总结:(采用哪种方式) 目前使用最广泛的是混合的构造函数/原型方式。此外,动态原型方法也很流行,在功能上与构造函数/原型方式等价。可以采用这两种方式中的任何一种。不过不要单独使用经典的构造函数或原型方式,因为这样会给代码引入问题。

推荐整理分享JavaScript定义类或函数的几种方式小结(javascript定义数组的方法),希望有所帮助,仅作参考,欢迎阅读内容。

JavaScript定义类或函数的几种方式小结(javascript定义数组的方法)

文章相关热门搜索词:js定义类的三种方法,javascript定义类型,javascript定义类型,js定义类的三种方法,js定义类的三种方法,javascript定义函数的方法,js定义类的三种方法,javascript 定义类,内容如对您有帮助,希望把文章链接给更多的朋友!

javascript中的对象创建 实例附注释 javascript中的对象创建声明:varobj={};或者varobj=newObject();为对象加入属性,方法://=====第一种写法====================================obj.name='小明';//为对象加属

javascript面向对象之一 定义类 javascript中的类是用函数function表示的,如下:functionStudent(){//定义类Student中的字段,并赋予初值,但此字段的访问权限是publicthis.studentNo='s';this.studentN

javascript面向对象之二 命名空间 最简单创建命名空间的方法:varjava={};java.util={};//这样就创建成功了命名空间:java.util//我们可以在java.util下面加类(函数),属性,或对象java.util.HashMap=func

标签: javascript定义数组的方法

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

上一篇:js对象的构造和继承实现代码(js对象的常用方法)

下一篇:javascript中的对象创建 实例附注释(js对象用法)

  • 个人注册电子税务局
  • 企业缴纳增值税会计科目怎么做
  • 企业转出多交增值税吗
  • 停车费增值税税率
  • 出口退税进项税
  • 企业可以找审计人员吗
  • 税务信用级别为m级
  • 增值税无票收入可以抵扣
  • 退休职工怎么填写单位吗
  • 资产负债表中的货币资金怎么算
  • 企业清算货币资金怎么算
  • 期末库存农产品进项转出如何算
  • 转登记为小规模纳税人政策
  • 损益表上的数据怎么看
  • 财务费用手续费有哪些
  • 开具红字专用发票的情形
  • 小规模纳税人增值税优惠政策2023
  • 房产税从价计征的计税依据
  • 公司不盈利用交税吗
  • 二月份个税申报时间
  • win10误删系统软件怎么还原
  • linux虚拟机怎么输入中文
  • u盘写入扇区错误
  • 中介公司收取中介费过高违法吗
  • 企业之间的违约金进什么科目
  • 投资收益或亏损影响营业利润吗
  • 洗牙的利和弊
  • 其他综合收益和其他收益的区别
  • 库存商品的主要类型
  • 电脑椅什么牌子质量好
  • 加计抵减现代服务税率
  • 火爆全网的头像男
  • 使用灭火器时要对准火焰的什么部位喷射
  • 跨年度多计提的附加税怎么做分录
  • 公司申报是每月一次吗
  • 税收筹划类型有哪几种
  • 小企业会计准则调整以前年度费用分录
  • 税务申报核定销售额在哪填写
  • 个税申报逾期罚款怎么算
  • 季度所得税申报错误,一定要更改吗
  • 个人所得税的征税范围
  • mysql服务器硬件配置
  • 自产用于捐赠的会计处理
  • 简易征收的税款可以抵减
  • 用友t6反记账步骤
  • 去年多计提的企业所得税怎么调整
  • 补交以前年度环保税
  • 盘亏存货可以转回来吗
  • 房地产经纪公司排名
  • 一般纳税人车辆租赁费的税率是多少
  • 公司基本账户有银行卡吗
  • mysql常见故障和解决方法
  • 世界杯猜测
  • SQLSERVER 中datetime 和 smalldatetime类型分析说明
  • vista win
  • mac系统制作
  • win8系统怎么设置
  • Ubuntu 14.10 “Utopic Unicorn”正式发布(附下载)
  • win7系统怎么启动讲述人
  • windows7使用
  • windows右键菜单
  • win7系统电脑开机密码怎么设置
  • windows 10 开始菜单
  • linux的命令行怎么打开
  • windows中创建的任务计划可以多久执行一次任务?
  • 文科生也能看懂的电子电路学PDf
  • Screen.sleepTimeout=SleepTimeOut.NeverSleep 禁止屏幕锁屏
  • python怎么计数
  • async/await与promise(nodejs中的异步操作问题)
  • 在unity中单例的主要作用
  • javascript 基础篇3 类,回调函数,内置对象,事件处理
  • js模拟用户点击
  • jquery瀑布流
  • js中input怎么用
  • 浅析2种JavaScript继承方式
  • 如何在网上查看自己的征信
  • 进货没有发票怎么报税
  • 大连国家税务局官网
  • 土地增值税扣除项目金额怎么计算
  • 武汉 工资 税
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设