位置: 编程技术 - 正文

javascript 面向对象编程基础:封装(javascript面向对象编程)

编辑:rootadmin

很长一段时间以来(这里本人要幸灾乐祸地说),js是“一种点缀的作用,完成很有限的功能,诸如表单验证之类,其语言本身也一直被当作过程化的语言使用,很难完成复杂的功能。”。但是(这里本人要苦大仇深、痛心疾首地说),“而Ajax的出现使得复杂脚本成为必需的组成部分,这就对 JavaScript 程序设计提出了新的要求,很多Ajax应用开始利用JavaScript面向对象的性质进行开发,使逻辑更加清晰。事实上,JavaScript 提供了完善的机制来实现面向对象的开发思想。”。额的神啊,本来就不想学不敢学的,现在不得不硬着头皮学了。 这里关于对象就废话这么多了。我们都知道面向对象编程的三个主要特点是:封装、继承和多态。下面就围绕着这三个特点,记录一些学习心得。 好的,先从封装性开始介绍,众所周知,对象是封装的最基本单位。封装防止了程序相互依赖性而带来的变动影响。面向对象的封装比传统语言的封装更为清晰、更为有力。Code is cheap.来看简单的代码: // 定义函数的方式定义类 function class1() { // 类成员的定义及构造函数 // 这里class1 既是一个函数也是一个类。作为函数,它可以理解为类的构造函数, 负责初始化的工作。 } // 使用new操作符获得一个类的实例 var obj = new class1(); /* 抛开类的概念,从代码的形式上来看,class1 就是一个函数,那么是不是所有的函数都可以用new来操作呢?答案是肯定的。 在JavaScript 中,函数和类就是一个概念,当new 一个函数时,就会返回一个对象。如果这个函数中没有初始化类成员,那就会返回一个空的对象。 事实上,当new一个函数时,这个函数就是所代表类的构造函数,其中的所有代码都可以看作为了初始化一个对象而工作。用于表示类的函数也称之为构造器。 在JavaScript 中,每个对象可以看作是多个属性(方法)的集合 */ function test() { alert( typeof (obj)); } 上面的代码定义了一个类class1,这就是js中简单的封装,下面我们看js如何定义“静态类”, function class1() { // 构造函数 } // 静态属性 class1.staticProperty = " test " ; // 静态方法 class1.staticMethod = function () { alert(class1.staticProperty); } function test() { // 调用静态方法 class1.staticMethod(); alert( typeof (class1)); } 接着看“抽象类”: /* 在传统面向对象语言中,抽象类中的虚方法必须先被声明,但可以在其他方法中被调用。 而在JavaScript 中,虚方法就可以看 该类中没有定义的方法,但已经通过this 指针使用了。 和传统面向对象不同的是,这里虚方法不需经过声明,而直接使用了。这些方法将在派生类 中实现 */ // 定义extend 方法 Object.extend = function (destination, source) { for (property in source) { destination[property] = source[property]; } return destination; } Object.prototype.extend = function (object) { return Object.extend.apply( this , [ this , object]); } // 定义一个抽象基类base,无构造函数 function base() { } base.prototype = { initialize: function () { this .oninit(); // 调用了一个虚方法 } } // 定义class1 function class1() { // 构造函数 } // 让class1继承于base 并实现其中的oninit方法 class1.prototype = ( new base()).extend({ oninit: function () { // 实现抽象基类中的oninit 虚方法 // oninit 函数的实现 } }); 我们看到,上面“让class1继承于base 并实现其中的oninit方法时”,使用了“继承”的概念,请留意。再来看一下执行的效果: function test() { var obj = new class1(); obj.oninit = function () { alert( " test " ); } obj.oninit(); }

推荐整理分享javascript 面向对象编程基础:封装(javascript面向对象编程),希望有所帮助,仅作参考,欢迎阅读内容。

javascript 面向对象编程基础:封装(javascript面向对象编程)

文章相关热门搜索词:javascript面向对象 第三方类库,javascript面向对象精要pdf下载,javascript面向对象吗,javascript面向对象编程指南 pdf,javascript面向对象编程,javascript面向对象编程指南,javascript面向对象精要pdf,javascript面向对象编程指南,内容如对您有帮助,希望把文章链接给更多的朋友!

javascript 面向对象编程基础:继承 我们看到这里继承的概念是多么的直白,拷贝一个类的prototype到另外一个类,好,Codeischeap,看代码:functionclass1(){}functionclass2(){}class2.prototype=class1.protot

javascript 面向对象编程基础 多态 Javascript已经可以模拟出面向对象的封装和继承特性,但是不幸的是Javascript对多态特性的支持非常弱!其它面向对象语言的多态一般都由方法重载和虚方

一个简单的javascript类定义例子 script//定义一个javascript类functionJsClass(privateParam/**/,publicParam){//构造函数varpriMember=privateParam;//私有变量this.pubMember=publicParam;//公共变量//定义私有方法functi

标签: javascript面向对象编程

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

上一篇:JS 面向对象的5钟写法(js中面向对象编程)

下一篇:javascript 面向对象编程基础:继承(javascript面向对象 第三方类库)

  • 财务软件里怎么输大于等于号
  • 印花税贴花是什么时候取消的
  • 休产假个人部分社保公司怎么做账
  • 小规模纳税人运输费计入什么科目
  • 外经证错了已经交了税怎么办
  • 个税身份证验证怎么弄
  • 法人独资企业怎么样
  • 所得税流程
  • 往来账项询证函一定要回复吗
  • 母公司为子公司担保需要股东会决议吗
  • 财产租赁所得适用什么税率
  • 企业支付给职工的工资和职工福利应当计入
  • 会计科目应收账款什么意思
  • 高速公路通行费电子发票怎么打印
  • 去税务局交的社保能退么
  • 花卉租赁的税率
  • 建筑施工企业清欠管理办法
  • 个人取得利息需要缴纳增值税吗
  • 影视行业如何盈利
  • 买二手车转让费一般要多少钱
  • 资源税的征税对象和纳税环节
  • 企业停产后员工怎么办
  • 无需付款的其他应付款怎么做凭证?
  • 多抵扣的进项如何做分录
  • 进出口免抵退税操作
  • office已经激活
  • 去年的发票可以红冲重新开具吗?
  • 怎么保存win10锁屏界面
  • 刚注册的有限公司可以马上注销吗
  • 进项票月初收到能抵上月
  • 退回的工伤费用怎么做账
  • php-msf
  • win10蓝牙怎么开ldac
  • 资产减值准备为什么在贷方
  • 增值税专票跨月但未认证,怎么作废
  • php获取变量长度
  • 未按规定开具发票怎么处罚
  • css实现轮播图侧边阴影效果
  • 企业会计核算应当以权责发生制为基础
  • 预付卡怎么开票
  • 基建账如何并入会计科目
  • web前端面试题2021及答案
  • 增值税进项税额能不能抵扣
  • 应交税费-应交增值税
  • 织梦模板改成帝国模板
  • 收到个人所得税手续费返还增值税税率
  • 限额领料单属于什么凭证多选题
  • 低值易耗品如何摊销
  • sql批量替换日期中的月份
  • access怎么提取数据
  • sql2005 数据同步方法
  • 火车票可以抵扣进项税
  • 实收资本期末需要结转吗
  • 同在一个单位
  • 公司法人往公司账户打钱怎么能换回来
  • 换下来的旧电池还有用吗
  • 应收账款无法收回会计分录
  • 行政单位 预算会计
  • 差旅费中住宿费的标准是什么
  • 购置一项设备,有两种可供选择
  • 固定资产的维修计入什么科目
  • 复利年金终值计算器
  • 营业成本占营业收入的比重过高
  • 备抵法核算坏账损失
  • 费用报销办法
  • sql中去掉结果为零的
  • win8升级win10系统会卡吗
  • fedora i3wm
  • WIN10系统怎么清理电脑c盘垃圾怎么清理
  • 经典璧纸
  • WFXMOD32.EXE - WFXMOD32是什么进程
  • win8 网络连接
  • Python探索之Metaclass初步了解
  • node_modules复制
  • css中显示
  • unity 形变
  • python类属性和类方法
  • 环保税征税范围噪音
  • 税务稽查证据问题
  • 成都市税务app
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设