首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

帮你彻底搞懂JSprototype、__proto__与constructor(图解)

前言   作为一名前端工程师,必须搞懂JSprototype、__proto__与constructor属性,相信很多初学者对这些属性存在许多困惑,容易把它们混淆,本文旨在帮助大家理清它们之间关系并彻底搞懂它们...但是由于JS函数也是一种对象,所以函数也拥有__proto__和constructor属性,这点是致使我们产生困惑很大原因之一。...感谢网友指出,这里解释一下上段“每个对象都有构造函数”这句话。...而单从constructor这个属性来讲,只有prototype对象才有。每个函数在创建时候,JS会同时创建一个该函数对应prototype对象,而函数创建对象....本文就此结束了,希望对那些对JSprototype、__proto__与constructor属性有困惑同学有所帮助。

1.2K20
您找到你想要的搜索结果了吗?
是的
没有找到

第197天:js---caller、callee、constructor和prototype用法

fn=function(n){ 36 if(n>0) return n+fn(n-1); 37 return 0; 38 } 39 alert('采用传统方式'+fn(10)); 三、constructor...1 // 什么是构造函数 - -专门用于创建对象或者累函数 -- 因为js中原来没有对象概念,通过函数来间接实现面向对象 2 //我们将创建对象时候那个函数称之为构造函数 3 //我们可以通过...constructor属性获取某个对象构造函数 4 //constructor 属性就是用来构造对象实例函数引用 - 后面的知识点 5 //构造函数 创建对象 6 function...7 this.name = name; 8 } 9 var zhangsan = new Student('张三'); 10 if (zhangsan.constructor...15 var str = new String("Hi"); 16 if (str.constructor == String) 17 document.write("

61920

彻底深刻理解js原型链之prototype,proto以及constructor(一)

前言 以下概念请花费一定时间彻底理解,才能进行下一步,思考题一定要思考,这样才能彻底掌握原型链知识点,教程如果有任何错误不足请指正!...思考: js引用数据类型都属于函数对象吗?...引用类型值:指的是那些保存在堆内存对象,意思是,变量中保存实际上只是一个指针,这个指针执行内存另一个位置,由该位置保存对象 那么数组,普通对象,函数对象都算是引用数据类型,引用数据类型范围包含函数对象范围...基本类型值:指的是保存在栈内存简单数据段;除开函数对象之外对象都是普通对象,那么普通对象范围是包含基本数据类型 事实上(函数对象,普通对象)以及(基本数据类型,引用数据类型)是在不同角度对js变量进行定义...所以答案是 js报错(有没有一种被我坑了感觉) 构造器constructor思考题解答 思考:a.prototype.proto.constructor指向谁?

79710

jssettimeout()用法详解_jssetattribute

大家好,又见面了,我是你们朋友全栈君。 setTimeout与setTimeInterval均为window函数,使用顶层window一般都会省去,这两个函数经常稍不留神就使用错了。...setTimeout内函数先不执行,隔一段时间后再执行,函数后面的数字是隔时间,单位是毫秒(千分之一秒) 比如: setTimeout(‘alert(“hello world!”)’..., 400); setInterval() 方法可按照指定周期(以毫秒计)来调用函数或计算表达式,直到clearInterval()被调用或窗口被关闭。 比如: Stop interval setInterval动作作用是在播放动画时...如发现本站有涉嫌侵权/违法违规内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

14.9K20

jsfind用法_jsfind函数

今天我们要说是结合ES6新特性谈一下js里面的一个很好用方法-find() 现在前端和过去不一样,过去前端只要会画页面就行了,但是现在仅仅会画页面已经远远不够了,现在前端还需要会处理数据,而且还要会将数据分析分类处理...下面我们讲怎么用前端处理这块逻辑 首先我们拿到了所有的数据这里我直接放到一个测试用js里面存放, 要实现之前说效果,就需要使用我们今天主角find()方法。 find()是用来做什么呢?...find()方法返回数组符合测试函数条件第一个元素。否则返回undefined 在本文章需要注意几个点: ①、第一个元素 ②、测试函数 那么如何使用呢?.../find_testcodes.js" type="text/javascript" charset="utf-8">

11.6K30

jsHook

简单理解:   hook(钩子)就是: 把将要执行函数或者一系列动作注册到一个统一接口下面, 当应用程序调用此接口(即hook)时,就等于调用了这一系列动作。...JS钩子(hook)例子 JS钩子(hook)例子1: 例如我们在向后台进行ajax请求时候,后台经常会返回我们一些常见错误码,如:001代表用户不存在,002代表用户密码输入错误。...这个时候我们要将错误友好提示给用户。这个时候我们该怎样实现呢?...一般写法可能是: $.ajax(option,function(result){ var errCode = result.errCode ;//错误码 if(errCode){...switch case来实现,但是这个两种写法都无法避免一个问题就是如果我错误码特别多,那得写多少个if else和case 啊?

6.5K31

Js堆栈

Js堆栈 堆heap是动态分配内存,大小不定也不会自动释放,栈stack为自动分配内存空间,在代码执行过程自动释放。...栈区 在栈内存中提供一个供Js代码执行环境,关于作用域以及函数调用都是栈内存执行。...Js基本数据类型String、Number、Boolean、Null、Undefined、Symbol,占用空间小且大小固定,值直接保存在栈内存,是按值访问,对于Object引用类型,其指针放置于栈内存...,堆内存存储实际对象,在栈内存存储对象指针,对于对象访问是按引用访问,在堆区内存不会随着程序运行而自动释放,这就需要实现垃圾回收机制GC,需要注意是在Js没有类似于Cfree()函数去手动释放内存...,从而决定是否需要进行内存回收,在Js主要有引用计数与标记清除两种垃圾回收算法。

3.1K30

Js变量

Js变量:  1:如果在var没有初始化变量值,则默认为undefined.  2:可以不用var来申明一个变量,但是在过程级申明一个变量时,就必须用var.   ...var currentCount  5: 在 JScript null 和 undefined 主要区别是 null 操作象数字 0,    而 undefined 操作象特殊值NaN (不是一个数字...请注意,比较大小时字符串自动转换为相等数字,但加法(连接)运算时保留为字符串。...js数据类型  1:Jscript 有三种主要数据类型、两种复合数据类型和两种特殊数据类型    主要(基本)数据类型是: 字符串 数值 布尔    复合(引用)数据类型是: 对象 数组    特殊数据类型是...: Null Undefined  2:测试是否已经声明变量 x :    if (typeof(x) == "undefined")      // 作某些操作 js内置对象  1:Jscript

12.9K60

js数据

数据、内存、变量 数据:以二进制形式存储在内存,代表一定信息数字。 内存:内存条通电后产生存储空间。内存又分为栈内存和堆内存。栈内存存放是全局变量或局部变量。而堆内存存放是对象。...,而obj1保存了obj内容,只是obj内容是{ name: 'clying' }地址值。...而存在与fun函数内部o变量,变成了垃圾对象,根本无法使用。 比较 可能会有一些疑惑:变量与函数,修改了obj值,为什么在引用变量与函数,obj值没有被修改?...首先需要明白,js函数传递变量参数时,是「值传递」(个人理解:传递是变量值)。执行函数fun,只是将obj地址值赋值给o变量。...变量与函数,o是直接被修改,修改直接是obj内部age属性变量。 引用变量与函数, 「o存放是obj值」,即:o内部是{ name: 'dengdeng', age: 22 }地址值。

5.5K20

js对象

js对象 在编程语言中,提到对象,一般都含有一个隐藏上下文面向对象编程。 面向对象编程(Object Oriented Programming,缩写为 OOP)是目前主流编程范式。..., cedf:function(){console.info("cdef")}, "arr":[1,2,3], o:{"name":"jake"} } “在js,对象是属性无序集合...1.2 集合 集合是说 对象可以有很多个属性。属性之间用逗号分隔。 1.3 无序 属性与属性之间,没有先后顺序之分。 对比一下,数组元素之间有序。...2. js对象分类 众观整个js对象,可以分成三类: 内置对象 宿主对象 自定义对象 2.1 内置对象 “由ECMA实现、不依赖于宿主环境对象,这些对象在js程序执行之前就已经存在了”。...js有两个运行环境: (1) 浏览器。我们在.html文件中加入js代码,再通过浏览器来打开,这里浏览器就是javascript运行环境。 在浏览器端js而言,宿主对象就是浏览器对象。

6.9K50
领券