位置: 编程技术 - 正文

JavaScript中几个重要的属性(this、constructor、prototype)介绍(javascript有哪些)

编辑:rootadmin
this this表示当前对象,如果在全局作用范围内使用this,则指代当前页面对象window; 如果在函数中使用this,则this指代什么是根据运行时此函数在什么对象上被调用。 我们还可以使用apply和call两个全局方法来改变函数中this的具体指向。 先看一个在全局作用范围内使用this的例子: 函数中的this是在运行时决定的,而不是函数定义时,如下: 全局函数apply和call可以用来改变函数中this的指向,如下: 注:apply和call两个函数的作用相同,唯一的区别是两个函数的参数定义不同。 因为在JavaScript中函数也是对象,所以我们可以看到如下有趣的例子: prototype prototype本质上还是一个JavaScript对象。 并且每个函数都有一个默认的prototype属性。 如果这个函数被用在创建自定义对象的场景中,我们称这个函数为构造函数。 比如下面一个简单的场景: 作为类比,我们考虑下JavaScript中的数据类型 - 字符串(String)、数字(Number)、数组(Array)、对象(Object)、日期(Date)等。 我们有理由相信,在JavaScript内部这些类型都是作为构造函数来实现的,比如: Array() { } arr1 = Array(1, , , ); arr2 = [1, , , ]; 同时对数组操作的很多方法(比如concat、join、push)应该也是在prototype属性中定义的。 实际上,JavaScript所有的固有数据类型都具有只读的prototype属性(这是可以理解的:因为如果修改了这些类型的prototype属性,则哪些预定义的方法就消失了), 但是我们可以向其中添加自己的扩展方法。 Array.prototype.min = () { min = [0]; ( i = 1; i < .length; i++) { ([i] < min) { min = [i]; } } min; }; console.log([1, , , ].min()); 注意:这里有一个陷阱,向Array的原型中添加扩展方法后,当使用for-in循环数组时,这个扩展方法也会被循环出来。 下面的代码说明这一点(假设已经向Array的原型中扩展了min方法): arr = [1, , , ]; total = 0; ( i arr) { total += parseInt(arr[i], ); } console.log(total); 解决方法也很简单: arr = [1, , , ]; total = 0; ( i arr) { (arr.hasOwnProperty(i)) { total += parseInt(arr[i], ); } } console.log(total); constructor constructor始终指向创建当前对象的构造函数。比如下面例子: 但是当constructor遇到prototype时,有趣的事情就发生了。 我们知道每个函数都有一个默认的属性prototype,而这个prototype的constructor默认指向这个函数。如下例所示: 当时当我们重新定义函数的prototype时(注意:和上例的区别,这里不是修改而是覆盖), constructor的行为就有点奇怪了,如下示例: 为什么呢? 原来是因为覆盖Person.prototype时,等价于进行如下代码操作: 而constructor始终指向创建自身的构造函数,所以此时Person.prototype.constructor === Object,即是: 怎么修正这种问题呢?方法也很简单,重新覆盖Person.prototype.constructor即可:

推荐整理分享JavaScript中几个重要的属性(this、constructor、prototype)介绍(javascript有哪些),希望有所帮助,仅作参考,欢迎阅读内容。

JavaScript中几个重要的属性(this、constructor、prototype)介绍(javascript有哪些)

文章相关热门搜索词:javascript分为,js有多少个函数,javascript分为,javascript有哪些,javascript分为,javascript有几种类型的值,javascript有几种类型的值,javascript有几种类型的值,内容如对您有帮助,希望把文章链接给更多的朋友!

JS特殊函数(Function()构造函数、函数直接量)区别介绍 函数定义函数是由这样的方式进行声明的:关键字function、函数名、一组参数,以及置于括号中的待执行代码。函数的构造语法有这三种:Js代码1.function

javascript之typeof、instanceof操作符使用探讨 写javascirpt代码时,typeof和instanceof这两个操作符时不时就会用到,堪称必用。但是!使用它们总是不能直接的得到想要的结果,非常纠结,普遍的说法认

深入理解javaScript中的事件驱动 javascript中的事件驱动是通过鼠标或热键的动作引发的主要事件如下:1、鼠标单击事件onclick如:(inputtype="button"value="鼠标单击"onclick="执行语句.处理"/)通

标签: javascript有哪些

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

上一篇:js函数中onmousedown和onclick的区别和联系探讨(js中onmouseover)

下一篇:JS特殊函数(Function()构造函数、函数直接量)区别介绍(js函数function用法)

  • 资本公积怎么核实
  • 财务报表没申报以后可不可以补申报
  • 研发费用直接计入成本吗
  • 零星采购范围
  • 发票红冲原票怎么处理
  • 预交所得税比较多怎么办?
  • 年底暂估成本有风险吗
  • 公司年底奖金怎么算
  • 递延收益在资产负债表哪里列示
  • 研发支出费用化支出每个月都要结转吗
  • 合作开发项目收益怎么算
  • 无偿代建政府公告
  • 货物运输政策
  • 增值税月报时间
  • 2021年沙子水泥税率是多少
  • 民办中小学收费新政策
  • 增值税小规模纳税人的税率
  • 融资租赁要怎么做
  • 信托公司如何投资
  • 定额发票2019年规定
  • 学校收到教育局拨款怎么做账
  • 增值税普通发票几个点
  • linux系统 推荐
  • 如何禁用bios里的secure boot
  • win7使用小技巧
  • 香椿的功效与作用百度百科
  • php字符串数组函数
  • php7.3安装
  • 辅导期一般纳税人标准
  • 担保公司未到期责任准备金会计及税务处理案例
  • 工程未审计资金能支付到多少
  • php连接mysql数据库的几种方式及区别
  • 投标文件中财务报表包括哪些内容
  • css点击菜单显示内容
  • 未开票收入为负数是什么意思
  • 应付账款的会计含义
  • 购买固定资产的运费计入什么科目
  • 个体工商户建账办法最新
  • 党费返还怎么记账
  • 油票上没有公司名称可以报么
  • 房产中介收取的贷款服务费合不合法
  • 应付货款和应付款的区别
  • 小企业会计准则适用于哪些企业
  • 单位全额承担社保能税前扣除吗
  • 公司注销持股1%的股东需要他签字吗
  • mysql切片
  • 未认证和未抵扣的区别
  • 红冲作废怎么处理
  • 代垫电费收回开票吗
  • 营业执照是什么字体
  • 购买预付卡如何开发票
  • 第三方代缴社保合法吗最新规定
  • 生产的产品不合格,追究时公司已经注销
  • 固定资产处置如何申报企业所得税
  • 或有租金租赁
  • 电费发票应收电费怎么开
  • mysql子查询效率如何
  • 在windows中创建用户的步骤
  • linux 解析
  • centos禁止ip访问
  • win10浏览器下载不了软件怎么回事
  • 如何在mac中安装五笔字型输入法
  • windows7旗舰版怎样扩大虚拟内存
  • linux的命令行界面
  • glCopyBufferSubData
  • 一个简单的群规内容
  • 用wasfile.zip智能批量删除文件
  • js中math.pow
  • jquery.validate[.unobtrusive]和Bootstrap实现tooltip错误提示问题分析
  • jquery keydown
  • 实用的app都有哪些
  • Metaio in Unity3d 教学--- 一. 搭建环境,运行官方案例
  • JQuery绑定事件的函数是
  • python 断言详细讲解用法及其案例
  • 上海各区税务大厅
  • 微信群记账小程序
  • 苏宁易购的联系电话
  • 纳税人如何划分
  • 税务稽查团队
  • 大班直播课怎么上
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设