位置: 编程技术 - 正文

Javascript创建类和对象详解(js如何创建类)

编辑:rootadmin

推荐整理分享Javascript创建类和对象详解(js如何创建类),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:js创建一个类,js类的创建,js创建类的方法,js创建类的方法,js创建类的方法,javascript创建对象及应用,javascript创建对象及应用,JavaScript创建类,内容如对您有帮助,希望把文章链接给更多的朋友!

现总结一下Javascript创建类和对象的几种方法:

1、原始的创建方法:

原始的创建方法对于熟悉面向对象的人来说难以接受,总感觉属性和方法的封装不是很紧密,这种封装是以“对象名”+“.”的方式进行,表示对象名后跟的属性和方法是这个对象拥有的东西,这个对象(例如:person)就是封装好的结果,你可以继续追加方法和属性,例如追加age属性:person.age=;这种创建方法会让熟悉Java编程的人感到很难受。我们可以对原始的创建方法进一步“封装”一下,请看下一步:

2、工厂方法模式:

工厂方法模式看起来更像一个类了,personFactory对原始的创建方法进行了封装,并将创建好的对象返回给person引用变量,person就可以引用这个创建好的对象了,但是还不够完美:你每一次创建一个对象, 并使用该对象调用show()方法时,都会创建新的show()函数,它们完全可以调用同一个show方法,优化方法是将show放到工厂外,如下:

Javascript创建类和对象详解(js如何创建类)

从功能上说,上面的代码解决了函数重用问题,但是呈现方式不像是创建一个对象,熟悉Java的人仍感到难受。请看下一步:

3、构造方法模式:

上述代码的创建方式已经与Java类和对象的创建方式几乎一样了,封装好类的属性和方法,然后利用new关键字创建并返回一个对象,这不就是Java创建类和对象的过程吗,是的,就是这个过程,但是还可以优化,这种方式创建的对象调用show方法是也会即时地创建一个show函数,我们能不能创建一个所有对象公用的一个方法呢?就像Java类中的static方法一样,所有对象都使用同一个static方法,答案是可以的。请看下一步:

4、动态原型方法:

这里使用了一点技巧,当用new创建对象是,会执行Person功能块中的if判断语句,顺序从上往下,刚开始tag变量当然没有定义,所以执行if语句块里的内容:

这段内容的含义是创建一个属于类Person的show方法,注意,它是一个类方法,相当于Java中static修饰后的方法,而非单个对象的方法,这样所有的对象均可调用同一个方法了,这样也不用每次不同对象调用方法是都创建自己的show函数了,既节省空间又节省时间,这种方法岂不更妙。这里解释一下,以“类名.prototype.属性/方法”方式构造的属性和方法相当于Java中用static修饰的变量或方法,是属于整个类的,而非单个的对象,也即所有对象是共享的。

以上是学习JS类和对象的总结,其中个人理解错误之处还望大家批评指正。

JavaScript箭头(arrow)函数详解 为了保证可读性,本文采用意译而非直译。另外,本文版权归原作者所有,翻译仅用于学习。本文我们介绍箭头(arrow)函数的优点。更简洁的语法我们先

JavaScript基础之this详解 JavaScript的this和Java等面向对象语言中的this大不一样,bind()、call()和apply()函数更是将this的灵活度进一步延伸。为了保证可读性,本文采用意译而非直译

JS失效 提示HTML: (UNICODE 字节顺序标记)的代码页 utf-8 覆盖(META 标记)的冲突的代码页 utf-8 经过分析发现,这个是因为页面中html与js编码不一致导致的,一般情况最好统一标准的utf8的上网找了找,木有找到相关的解决办法,索性自己试了试。

标签: js如何创建类

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

上一篇:Javascript继承机制详解(js继承怎么实现)

下一篇:JavaScript箭头(arrow)函数详解(js 箭头表达式)

  • 企业投资收益要开发票吗
  • 用友t3核算管理模块怎么结账
  • 购货方收到红字发票
  • 确认增值税时要通过未缴增值税科目吗
  • 资产负债表本月期末余额怎么填
  • 审核通过的红字发票信息表可以撤销吗
  • 租车纳税
  • 自然人股权转让的纳税筹划
  • 二手车交易怎么办理过户手续
  • 抵押贷款合同印花税怎么算
  • 国税注销了地税没注销现在经营异常
  • 堤围工程
  • 小规模纳税人附加税减半征收
  • 税务行业软件
  • 买标书怎么做分录
  • 出口退税预审在申报系统怎么做
  • 电子钥匙到期怎么办
  • 银行对账单不平衡
  • 所得税收入包含哪些
  • 城镇退役士兵安置条例
  • 租车费增值税专用发票
  • 1697510490
  • 无需付款的其他应付款怎么做凭证?
  • 产品质量监督检验
  • wifi上传速度为0的解决方法
  • 企业去银行办理贷款需要什么
  • vue3使用vueup/vue-quill富文本、并限制输入字数
  • 银行本票出票金额大于账户余额
  • 已计提完的固定资产怎么弄
  • 浏览器windows下载
  • 今天是520该说什么
  • 史上伟大电影
  • 数据库 元数据
  • python的切片操作
  • 合伙企业的经营所得税率
  • wordpress woocommerce 建站
  • 开票金额应该含增值税吗
  • 织梦如何添加浮动广告
  • mongodb 日志
  • 企业所得税汇算清缴补缴税款分录
  • 采购商品没有进账怎么做账
  • 应收账款计入营业收入
  • 材料成本差异的超支与节约
  • 小微企业所得税税率
  • 怎么作废银联在网上银行
  • mysql查询字段为空的数据
  • 当月的进项税可以不认证吗?
  • 认证过的发票红冲了还要退回吗
  • 在建工程账务处理会计分录
  • 管理费用抵扣企业所得税的比例
  • 企业间借款利息最新规定
  • 计时工资和计件工资的含义
  • 进项税额有抵扣期限吗
  • 首先我们先了解一下作者英语怎么说呢
  • 收到了对方的作业怎么办
  • 没有关联企业怎么选不了否
  • 盈余公积什么时候会出现在账面
  • 职工福利费的核算内容
  • 采用账龄分析法计提坏账准备
  • sql server数据库查询语句
  • centos6.1安装
  • winxp如何访问win10
  • centos6.10修改主机名
  • SUSE Linux Enterprise Server 11 SP3安装教程详解
  • windows10网页打不开怎么办
  • linux的收获
  • win+tab键
  • win8系统升级
  • KbdTray.exe - KbdTray是什么进程 有什么作用
  • ubuntu怎么安装程序
  • springmvc接收form表单
  • android游戏编程之从零开始
  • cocos 2d x
  • web标准网页布局的背景
  • 显示解析包时出错是怎么回事
  • python3循环语句
  • java urlencode如何使用
  • 无序列表html
  • 个人开具农产品普通发票
  • 税务机关垂直领导
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设