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

JS原型原型

原型原型 JavaScript有着七种基本类型String、Number、Boolean、Null、Undefined、Symbol、Object,前六种为基本数据类型,Object为引用类型。...值得注意的typeof (null)会返回Object,这是因为JS二进制前三位都为0的话会被判断为Object类型,null的二进制表示全0,自然前三位也是0,所以执行typeof时会返回Object...new Student(); console.log(stu1.from) // sdust console.log(stu2.from) // sdust __proto__ __proto__ 原型查询中实际用到的...原型可以简单理解为将原型连成一条js每一次获取对象中的属性都是一次查询过程,如果在自有属性中找不到就会去原型对象中查找,如果原型对象中还查不到,就回去原型对象的原型中查找,也就是按照原型查找,...直到查找到原型的顶端,也就是Object的原型

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

js原型

显示原型 1.每一个构造函数都有一个prototype属性,默认指向一个空Object对象(原型对象) function fun(){ } console.log(fun.prototype ) //{...) //true 5.构造函数与它的原型对象有一个相互引用的关系 6.原型对象上添加的方法用于实例对象上使用 隐式原型 每一个实例对象都有一个__proto__属性,称之为隐式原型 对象的隐式原型的值为其对应构造函数的显示原型的值...__proto__) Fn.prototype.test = function(){ console.log('test') } fn.test() 原型 对象属性的查找规则 原型本质上从隐式原型...test2,发现有直接调用test2 当执行fn.toString(),时,自身对象没有,接下来查找它构造函数的原型对象上是否有toString(),发现没有,接下来又继续沿着Fn原型对象的构造函数的原型对象上查找找到...toString() 当执行fn.test3()时,查找自身对象没有,它直接的构造函数对象的原型对象上也没有,接下来沿着Fn原型对象的构造函数的原型对象的构造函数的原型对象上查找,这里已经找到原型的尽头

2.1K20

js原型原型解析

js原型原型 这几天闲了看了下js原型,以下内容为个人理解,如有错误,尽请指正。...,使用__proto__将所有对象联系起来,才形成了所谓的原型,举个栗子: function Person() {} const p1 = new Person() console.log(p1....__proto__ === Object.prototype) // true, Person的原型由Object构造的,因为Person.prototype一个普通对象,普通对象的构造都是Object...__proto__ === null) // true, Object的原型由null"产生"的,null处于原型顶端 这个从根本上印证了道德经那句:道(null)生一,一生二,二生三,三生万物...4、一般我们通过.操作符获取一个对象的属性或方法的时候,会首先在当前对象自身上查找该属性或方法,找不到的话会继续顺着__proto__也就是原型向上查找,直到找到,否则返回undefined,举个栗子

2.1K30

【深入理解JS核心技术】2. 什么原型

原型用于在现有对象的基础上构建新类型的对象。它类似于基于类的语言中的继承。...构造函数,原型,实例的关系: 每个构造函数都有一个原型对象,原型有一个属性指回构造函数,而实例有一个内部指针指向原型原型的基本思想:(如果原型另一个类型的实例?)原型当成实例。...第一种方式使用instanceof操作符,如果一个实例的原型中出现过相应的构造函数,则instanceof返回true。 确定关系的第二种方式使用 isPrototypeOf() 方法。...原型中的每个原型都可以调用这个方法。...原型中包含的引用值会在所有实例间共享,这也是为什么属性通常会在构造函数中定义而不会在原型上的原因。

33310

JS原型温故

方法 3var fn = new Fn(); //通过构造函数Fn进行new出来一个实例对象fn, 4 5//fn的原型指向Fn的原型 6//即:fn....每个对象都有一个隐式原型,即__proto__,对象的__proto__指向该对象构造器的prototype原型。...所以结合上面几个图,可以形成这样一个结论: 在JS世界中,null为开始,由null开始衍生出Object.prototype。Object.prototype的隐式原型指向null。...从上图可以看出一个关系,那就是js中的各对象间都是通过原型来互相连接起来的,这个原型将所有对象链接在了一起,这就是为什么JS基于原型的面向对象编程语言,即使现在有es6 7有了class类,它本质上也是基于原型形成的语法糖而已...js中实现的继承就是通过这条原型来工作的:在访问一个对象的某个属性时,先该对象的现有属性中查找,如果没有,再沿着__proto__这种向上找,这就是原型

1.3K20

理解JS 原型

但是你总不能说他们一间麦当劳吧?...#原型 原型简单用一句话概括就是: 原型就是 对象的__proto__所连接的状结构 为了方便我们理解原型,举一个简单的例子: function F(){ this.a = 1;...图中这条红色的线就是原型。 由此可见,实例对象可访问自己原型对象上的属性和方法,额..准确来说是: 当一个对象 查找属性或方法时,自己有,停止查找,返回结果。...#补充 constructor 说一下我的经历,一开始理解原型时,一直在prototype、__proto__、constructor在这个三个属性中绕来绕去。...null 既然对象都会继承自Object.prototype上面的方法,那它自己的原型又是什么呢。答案null Object.prototype.

1.7K10

JS面试必问-JS原型原型

什么需要原型js中万物皆对象,对象可以说是重中之重了。每一个对象都拥有自己的属性。但是在这个世界中有很多东西都是相似的,可以归为一类,他们有共同的方法和属性。不可能让每一个对象都定义一个属性吧。...什么原型对象 声明一个构造函数 function students() { /* 我就是构造函数 */ } 在声明了一个函数之后,浏览器会自动按照一定的规则创建一个对象,这个对象就叫做原型对象...原型对象有一个constructor属性,默认指向对应的构造函数。 什么原型 根据字面意思我们可以这样理解,就是将原型连成一条。...我们上面讲过,js每一次获取对象中的属性都是一次查询过程,如果在自有属性中找不到就会去原型对象中查找,如果原型对象中还查不到,就回去原型对象的原型中查找,也就是按照原型查找,直到查找到原型的顶端,也就是...在js中,对象都有__proto__属性,一般这个被称为隐式的原型,该隐式原型指向构造该对象的构造函数的原型

1.6K20

JS中的原型原型

prototype就是调用构造函数所创建的实例对象的原型(proto)。js在创建对象的时候,都有一个叫做proto的属性,用于指向它的函数对象的原型对象prototype。...原型 每一个对象都可以有一个原型,这可原型还可以有它自己的原型,以此类推,就形成了原型。...查找一个对象的属性或方法的时候,如果这个对象中没有这个属性或者方法,那就会在这个对象的原型对象中去找,以此类推,直到原型链结束。..._proto_ _proto_原型查询中实际用到的,指向构造函数的原型对象,他对象独有的。对象._proto_ = 构造函数.prototype。 在js中,万物皆是对象,函数也是对象。...3、构造函数的prototype指向原型对象,原型对象的constructor指向构造函数。 使用 prototype最主要的用法就是将属性暴露成公用的。

1.5K10

彻底搞懂JS原型原型

说到JavaScript的原型原型,相关文章已有不少,但是大都晦涩难懂。本文将换一个角度出发,先理解原型原型什么,有什么作用,再去分析那些令人头疼的关系。...也就是说 数组对象、函数对象、正则是对象、对象还是对象。图片二、原型原型什么上面我们说到对象就是属性(property)的集合,有人可能要问不是还有方法吗?...现在我们已经初步理解了原型原型,到现在大家明白为什么数组都可以使用push、slice等方法,函数可以使用call、bind等方法了吧,因为在它们的原型上找到了对应的方法。...参考视频讲解:进入学习五、原型顶层原型之所以叫原型,而不叫原型环,说明它是有始有终的,那么原型的顶层是什么呢?...图片七、函数对象的原型之前提到过引用类型皆对象,函数也是对象,那么函数对象的原型怎么样的呢?对象都是被构造函数创建的,函数对象的构造函数就是Function,注意这里F大写。

1.7K20

彻底弄懂JS原型原型

说到JavaScript的原型原型,相关文章已有不少,但是大都晦涩难懂。本文将换一个角度出发,先理解原型原型什么,有什么作用,再去分析那些令人头疼的关系。...也就是说 数组对象、函数对象、正则是对象、对象还是对象。图片二、原型原型什么上面我们说到对象就是属性(property)的集合,有人可能要问不是还有方法吗?...现在我们已经初步理解了原型原型,到现在大家明白为什么数组都可以使用push、slice等方法,函数可以使用call、bind等方法了吧,因为在它们的原型上找到了对应的方法。...五、原型顶层原型之所以叫原型,而不叫原型环,说明它是有始有终的,那么原型的顶层是什么呢?拿我们的person对象来看,它的原型对象,很简单// 1. person的原型对象person....图片七、函数对象的原型之前提到过引用类型皆对象,函数也是对象,那么函数对象的原型怎么样的呢?对象都是被构造函数创建的,函数对象的构造函数就是Function,注意这里F大写。

1.1K40

js中的原型原型

​一、原型 1、prototype和constructor 在js中每个函数(非箭头函数,一般关于原型的有关知识我们都只考虑构造函数)都会拥有一个 prototype 属性,该属性值一个对象...__proto__) // true 二、原型 原型:《JavaScript高级程序设计》中的描述:每个构造函数都有一个原型对象,如果该原型另一个类型的实例呢?...那就意味着这个原型本身有一个内部指针指向另一个原型,相应地另一个原型也有一个指针指向另一个构造函数。这样就在实例和原型之间构造了一条原型。这就是原型的基本构想。...原型中的查找机制:实例对象上找不到指定属性,就从该原型对象上找,如果还是找不到就到该原型对象上的原型上去找,。...第一个参数:要设置其原型的对象;第二个参数:该对象的新原型(一个对象或 null)。

1.1K00

js对象和原型原型的关系

JS原型原型一直比较难理解的内容,不少初学者甚至有一定经验的老鸟都不一定能完全说清楚,更多的"很可能"一知半解,而这部分内容又是JS的核心内容,想要技术进阶的话肯定不能对这个概念一知半解,碰到问题靠...原因:People1和People2的原型People.prototype,答案在下方的:构造函数是什么以及它做了什么。...、它做了什么出自《你不知道的js》:在js中, 实际上并不存在所谓的'构造函数',只有对于函数的'构造调用'。...JS基础的题,很多人都没说对,原因没有彻底掌握this、原型、函数。...原型对象改变,原型下游获取的值也会改变上面那个例子中的foo1.test的值是什么

1.5K20
领券