位置: 编程技术 - 正文

[推荐]javascript 面向对象技术基础教程([推荐]抖音上那些好看的视频和有才的帐号)

编辑:rootadmin

结果呢,看了大半天,有了一个大概的了解,细细一回味,好像什么都没懂... 这篇文章是参考<<javascript-the definitive guide,5th edition>>第7,8,9章而写成的,我也 会尽量按照原书的结构来说明javascript的面向对象技术(对象/数组->函数-->类/构造函数/原型).对一些我自己也拿捏不准的地方,我会附上原文的英文语句,供大家参考. 如果不做说明,则文中出现的所有英文语句(程序体除外)都是引自<<javascript-the definitive guide,5th edition>>. ------------------------------------------------- 对象和数组(Objects and Arrays) 什么是对象?把一些"名字-属性"的组合放在一个单元里面,就组成了一个对象.我们可以理解为javascript中 的对象就是一些"键-值"对的集合(An object is a collection of named values. These named values are usually referred to as properties of the object.--Section3.5). "名字"只能是string类型,不能是其他类型,而属性的类型则是 任意的(数字/字符串/其他对象..).可以用new Object()来创建一个空对象,也可以简单的用"{}"来创建一个 空对象,这两者的作用是等同的. 从上面的例子我们也可以看到,访问一个对象的属性,可以简单的用对象名加"."后加属性的名字,也可以用"[]"操作符来获取,此时在[]里面的属性名字要加引号,这是因为对象中的索引都是字符串类型的. javasript对象中属性的个数是可变的,在创建了一个对象之后可以随时对它赋予任何的属性. 通过"."操作符获取对象的属性,必须得知道属性的名字.一般来说"[]"操作符获取对象属性的功能更强大一些, 可以在[]中放入一些表达式来取属性的值, 比如可以用在循环控制语句中,而"."操作符则没有这种灵活性。 delete操作符可以删除对象中的某个属性,判断某个属性是否存在可以使用"in"操作符. 需要注意,对象中的属性是没有顺序的. 对象的constructor属性 每一个javascript对象都有一个constructor属性.这个属性对应了对象初始化时的构造函数(函数也是对象). 数组 我们已经提到过,对象是无序数据的集合,而数组则是有序数据的集合,数组中的数据(元素)通过索引(从0开始)来访问, 数组中的数据可以是任何的数据类型.数组本身仍旧是对象,但是由于数组的很多特性,通常情况下把数组和对象区别 开来分别对待(Throughout this book, objects and arrays are often treated as distinct datatypes. This is a useful and reasonable simplification; you can treat objects and arrays as separate types for most of your JavaScript programming.To fully understand the behavior of objects and arrays, however, you have to know the truth: an array is nothing more than an object with a thin layer of extra functionality. You can see this with the typeof operator: applied to an array value, it returns the string "object". --section7.5). 创建数组可以用"[]"操作符,或者是用Array()构造函数来new一个. Js代码 用new Array()来创建数组时,可以指定一个默认的大小,其中的值此时为undefined,以后可以再给他们赋值.但是由于 javascript中的数组的长度是可以任意改变的,同时数组中的内容也是可以任意改变的,因此这个初始化的长度实际上 对数组没有任何的约束力.对于一个数组,如果对超过它最大长度的索引赋值,则会改变数组的长度,同时会对没有赋值 的索引处赋值undefined,看下面的例子. Js代码 可以用delete操作符删除数组的元素,注意这个删除仅仅是将数组在该位置的元素设为undefined,数组的长度并没有改变. 我们已经使用过了数组的length属性,length属性是一个可以读/写的属性,也就是说我们可以通过改变数组的length属性来 任意的改变数组的长度.如果将length设为小于数组长度的值,则原数组中索引大于length-1的值都会被删除.如果length 的值大于原始数组的长度,则在它们之间的值设为undefined. Js代码 对于数组的其他方法诸如join/reverse等等,在这就不再一一举例. 通过上面的解释,我们已经知道,对象的属性值是通过属性的名字(字符串类型)来获取,而数组的元素是通过索 引(整数型 0~~2**-1)来得到值.数组本身也是一个对象,所以对象属性的操作也完全适合于数组. Js代码 函数 javascript函数相信大家都写过不少了,所以我们这里只是简单介绍一下. 创建函数: 上面这两种形式都可以创建名为f()的函数,不过后一种形式可以创建匿名函数 函数定义时可以设置参数,如果传给函数的参数个数不够,则从最左边起依次对应,其余的用undefined赋值,如果传给函数 的参数多于函数定义参数的个数,则多出的参数被忽略. Js代码 因此,对于定义好的函数,我们不能指望调用者将所有的参数全部传进来.对于那些必须用到的参数应该在函数体中 加以检测(用!操作符),或者设置默认值然后同参数进行或(||)操作来取得参数. Js代码 函数的arguments属性 在每一个函数体的内部,都有一个arguments标识符,这个标识符代表了一个Arguments对象.Arguments对象非常类似 于Array(数组)对象,比如都有length属性,访问它的值用"[]"操作符利用索引来访问参数值,但是,二者是完全不同的 东西,仅仅是表面上有共同点而已(比如说修改Arguments对象的length属性并不会改变它的长度). Js代码 Js代码 Method--方法 方法就是函数.我们知道,每一个对象都包含0个或多个属性,属性可以是任意类型,当然也包括对象.函数本身就是一种 对象,因此我们完全可以把一个函数放到一个对象里面,此时,这个函数就成了对象的一个方法.此后如果要使用该方法, 则可以通过对象名利用"."操作符来实现. Js代码 方法的调用需要对象的支持,那么在方法中如何获取对象的属性呢?this!this关键字我们已经很熟悉了,在javascript的方 法中,我们可以用this来取得对方法调用者(对象)的引用,从而获取方法调用者的各种属性. Js代码 下面我们来一个更加面向对象的例子. Js代码 在上面的例子中,完全可以用person.name=..来直接改变person的name属性,在此我们只是为了展示一下刚才提到的内容. 另一种改变person属性的方法就是:定义一个function,接收两个参数,一个是person,一个是name的值,看起来像是这样: changeName(person,"newName").哪种方法好呢?很明显,例子中的方法更形象,更直观一些,而且好像有了那么一点面向 对象的影子. 再次强调一下,方法(Method)本身就是是函数(function),只不过方法的使用更受限制.在后面的篇幅中,如果提到函数,那么 提到的内容同样适用于方法,反之则不尽然. 函数的prototype属性 每一个函数都包含了一个prototype(原型)属性,这个属性构成了javascript面向对象的核心基础.在后面我们会详细讨论.

推荐整理分享[推荐]javascript 面向对象技术基础教程([推荐]抖音上那些好看的视频和有才的帐号),希望有所帮助,仅作参考,欢迎阅读内容。

[推荐]javascript 面向对象技术基础教程([推荐]抖音上那些好看的视频和有才的帐号)

文章相关热门搜索词:[推荐饭拍]100911 SMT in Shanghai,推荐java设计模式书籍推荐,[推荐下载],[推荐下载],推荐javascript教程,[推荐] 实现移动端到端加密的基础(一),[推荐] 实现移动端到端加密的基础(一),推荐java书籍,内容如对您有帮助,希望把文章链接给更多的朋友!

小型js框架veryide.librar源代码 /**CopyrightVeryIDE,-*

JavaScript RegExp方法获取地址栏参数(面向对象) Request={QueryString:function(item){varsvalue=location.search.match(newRegExp('[?&]'+item+'=([^&]*)(&?)','i'));returnsvalue?svalue[1]:svalue;}}varkey=Request.QueryString('key');Request.QueryString

JavaScript 面向对象入门精简篇第1/2页 封装:javascript中创建对象的模式中,个人认为通过闭包才算的上是真正意义上的封装,所以首先我们先来简单介绍一下闭包,看下面这个例子:scripttype

标签: [推荐]抖音上那些好看的视频和有才的帐号

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

上一篇:js继承 Base类的源码解析(js常用继承)

下一篇:小型js框架veryide.librar源代码(js 模板框架)

  • 分公司不独立核算怎么做账
  • 待抵扣进项税额是什么意思
  • 领用本企业生产的水泥用于在建工程
  • 存货清查会计分录例题盘亏
  • 现金支票提取现金备用
  • 出口退回的增值税计入哪个会计科目
  • pos刷的钱能追回吗
  • 个人账户可以转公户吗?
  • 向消费者支付佣金怎么算
  • 钢结构制作安装合同
  • 滴滴打车税收问题
  • 一般纳税人注销需要多少钱
  • 奖金个人所得税筹划
  • 税务师几年内考完几门
  • 自查补缴税款严重吗
  • 企业的其他业务收入包括
  • 支付工会经费
  • SWNETSUP.EXE - SWNETSUP是什么进程 有什么用
  • 进口货物可以退回吗
  • 出售报废固定资产的净损失计入什么科目
  • 职工教育经费培训费扣除比例
  • 法定盈余公积金转增资本
  • 在win7中怎么安转只兼容win10的软件
  • 公司的贷款过桥怎么办
  • win11安卓子系统在哪打开
  • 外贸企业退税需要哪些资料
  • PHP:ob_iconv_handler()的用法_iconv函数
  • nodejs怎么更新版本
  • 补发工资怎么做账
  • 黄石国家公园的建立意义
  • Yii2实现ajax上传图片插件用法
  • thinkphp 模块
  • 毕业设计基于51单片机多功能电子钟的设计
  • 数据挖掘论文选题
  • 送货运输费用税率
  • 车辆购置税是税前还是税后
  • 固定资产折旧怎么做会计科目
  • 织梦怎么改网站主页
  • sqlserver数据类型转换函数
  • spring10
  • 怎么做零售企业
  • 汽车车票增值税税率
  • 购汽车能抵扣进项吗
  • 装订会计凭证步骤
  • 边际贡献分析法案例
  • 建筑业跨区域预缴税款的计算
  • 建筑业 分包
  • 应交税费减免税款怎么结转
  • 公司员工入职的心得体会
  • 普通进项发票怎么做分录
  • 收到个人款怎么做分录
  • 淘宝卖家运费险为什么越来越贵
  • 非包销的视同买断的账务处理是?
  • 生产车间买的工具计入什么费用
  • sql server错误代码1608
  • 深度解析桂附地黄丸
  • debian系统如何安装软件
  • win7系统隐藏文件夹怎么取消隐藏
  • linux ifconfig命令详解
  • centos配置yum
  • 桌面管理在哪里打开
  • win8摄像头设置
  • 搜索应用界面
  • windows8.
  • Win10 Build 14316启用Linux Bash 环境图文教程
  • jquery简单网页
  • easyui datagrid resize
  • shell基础教程
  • python的pip安装命令
  • 实用的批处理
  • 原生js实现ajax步骤
  • nodejs图片上传
  • android零基础
  • javascript零基础
  • html伸缩布局
  • cocos creator android
  • 农产品进项税额核定扣除办法2019
  • 河南2020年机构改革
  • 上海税务培训中心
  • 网上预约税务局怎么弄
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设