位置: 编程技术 - 正文

[推荐]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 模板框架)

  • 开咨询费需要合同吗
  • 信息技术服务开票单位填什么
  • 服装纳税税率
  • 固定资产减少当月
  • 有发票章的存根联可以当发票用吗
  • 注册资本低于实际投资
  • 电子凭证是否具有法律效力
  • 用友薪资管理怎么重新初始化步骤
  • 质量保证金的预留比例是多少
  • 土地流转承包费拖欠
  • 个人保证金业务
  • 一个月怎么控制花一千块
  • 企业利润怎么拿出来
  • 个人名义帮公司贷款
  • 个税手续费返还计入哪个科目
  • 公司税务注销了还有风险吗
  • 开票软件维护费计入什么科目
  • 最新事业单位固定资产折旧规定
  • 进项大于销项怎么做账
  • 出售专利权属于什么科目
  • 销项负数发票需要抵扣吗
  • 政府高薪补贴
  • 公司注销其他应收款怎么冲平
  • 展厅设计费用计什么科目
  • win10如何禁用administrator用户
  • 笔记本电脑怎么重装系统
  • 细说php
  • php源码怎么上传到服务器
  • 网络连接错误是什么意思啊
  • thinkphp autoload 命名空间自定义 namespace
  • PHP:imagepsfreefont()的用法_GD库图像处理函数
  • 房产税应计入哪个会计科目
  • php 查找数组元素
  • 冰岛北部内陆景观有哪些
  • transformers document
  • 银行承兑汇票的付款人是谁?
  • Win11 Build 23430 预览版发布(附更新修复内容汇总)
  • springboot -d
  • wrap激活
  • 收回外币应收账款如何处理
  • bat 进入当前文件夹
  • 国家退税收到的钱在哪里
  • 技术开发费免税政策
  • 长期股权投资为什么不是金融资产
  • 怎么计算利润的百分比
  • 定期定额户用财务制度备案吗
  • 红冲更正的正确分录
  • 建筑公司工程款税率
  • 计提租金如何做账务处理
  • 基金可以一次性全部卖出吗
  • 工程材料票占工程款的比例
  • 企业股权无偿转让
  • 固定资产中如何计算折旧
  • 公司与公司之间劳务协议
  • 一般纳税人销售使用过的固定资产
  • 违反会计法规定的行为有哪些
  • 查询存储过程中的文件
  • 教你鉴别耳机音质的好坏的几大技巧
  • winxp更新到win10
  • windows自动操作软件
  • 系统维护的主要内容有哪些
  • 怎么简单快速的拼成魔方六面
  • 360 sesvc.exe
  • win8系统摄像头怎么打开
  • xp操作系统还能用吗
  • OS X Yosemite系统下载失败怎么办?OS X 10.10下载错误解决方法
  • Windows Server 2012实用技巧集锦
  • win7win8.1win10哪个好
  • windows defender 图标怎么从任务栏删除
  • windows10总是出现打印机错误
  • linux php 开发教程
  • 怎么做小地图图片呢
  • shell数值比较
  • python的入门教程
  • 基于python的推荐系统
  • jquery mobile demo
  • 开发Blog整理
  • 教你学python
  • 浙江省网上税务局app下载
  • 国家税务发票查验平台手机怎么查
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设