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

JS对象+构造函数+原型对象谈恋爱了嘛。

Person("zs", 44); obj2.say(); console.log(obj2.currentType); /** * prototype的特点:存在在原型对象里面的属性与方法可以被构造函数的所有对象所共享...* 如果原型与构造函数的属性与方法相同,优先级执行的是构造函数里面的,如果没有到原型里面找. */ ...);//构造函数里面的prototype指向了对象(原型对象) /*2.每个"原型对象"中都有一个默认的属性, 叫做constructor constructor指向当前原型对象对应的那个..."构造函数" */ console.log(Person.prototype.constructor);//原型对象里面的constructor属性指向了函数(当前原型对象对应的那个..."构造函数") /*3.通过构造函数创建出来的对象我们称之为"实例对象" 每个"实例对象"中都有一个默认的属性, 叫做__proto__ __proto__指向创建它的那个构造函数

1.2K10

js构造函数

//构造函数 //使自己的对象多次复制,同时实例根据设置的访问等级可以访问其内部的属性和方法 //当对象被实例化后,构造函数会立即执行它所包含的任何代码 function myObject(msg...,在构造函数创建的每个实例中都会包含同样的私有和特权成员的副本, //因而实例越多占用的内存越多  } //公有方法 //适用于通过new关键字实例化的该对象的每个实例 //向prototype...;  } //静态属性 //适用于对象的特殊实例,就是作为Function对象实例的构造函数本身  myObject.name = 'china'; //静态方法  myObject.alertname...,然后在访问该类静态属性 //console.log(myObject.address); //undefined, myObject中的this指的不是函数本身,而是调用address的对象,而且只能是对象...(); //china, 调用该对象构造函数(类函数)的方法(函数) //m1.sayHello(); //hello everyone, myObject类的prototype原型下的方法将会被实例继承

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

秒懂JS对象构造函数和原型对象之间的关系

学习JS的过程中,想要掌握面向对象的程序设计风格,对象模型(原型和继承)是其中的重点和难点,拜读了各类经典书籍和各位前辈的技术文章,感觉都太过高深,花费了不少时间才搞明白(个人智商是硬伤/(ㄒoㄒ)/~...一、基本概念   1、对象:属性和方法的集合,即变量和函数的封装。每个对象都有一个__proto__属性,指向这个对象构造函数的原型对象。   ...2、构造函数:用于创建对象函数,通过new关键字生成对象函数名一般首字母大写的。   ...3、原型对象:每个函数都有一个prototype属性,它是一个指向原型对象的指针(原型对象在定义函数时同时被创建) 二、创建对象的方法   1、使用构造函数和原型对象共同创建 ?...如上图,构造函数Person(),通过new关键字创建了两个实例化对象p1、p2,这两个新对象都继承了,构造器Person()函数prototype属性所指向的原型对象

1.7K70

JS入门难点解析11-构造函数,原型对象,实例对象

2.4 普通调用返回undefined,而new调用返回一个对象构造函数A中的this指向了该对象,所以返回对象的属性和方法由构造函数中的this语句初始化。...总结:对于构造函数调用,有如下特点: 如果没有return,返回一个新的对象构造函数的this指向该对象。 如果有return且后面的返回值不是对象(包括函数),则return语句会被忽略。...实例对象:通过构造函数的new操作创建的对象是实例对象,又常常被称为对象实例。可以用一个构造函数构造多个实例对象。下面的f1和f2就是实例对象。...构造函数,原型对象和实例对象的关系 5.1 指向关系 构造函数A的prototype属性指向F与其实例对象(a1,a2,...)的原型对象A.prototype,该原型对象的constructor属性指向构造函数...参考 javascript面向对象系列第一篇——构造函数和原型对象 JS入门难点解析10-创建对象 深入理解js构造函数 JavaScript构造函数详解 BOOK-《JavaScript高级程序设计

1.6K10

构造函数隐式转换_构造函数实例化对象

转载博客: http://blog.csdn.net/thefutureisour/article/details/7705771 构造函数隐式转换 构造函数会引起一个不引人注意的问题: 用单个实参来调用的构造函数定义了从从形参类型到类类型的一个隐式转换...建立一个临时的类的对象(一旦函数调用结束,就不能再放这个对象了)。...为了避免这个情况的发生,可以将类的构造函数声明为explicit: explicit Sales_item(const std::string &book = "7115145547"):isbn(book...所以对于单形参构造函数,除非有非常明显的理由让他发生隐式类型转换,否者我们应该把它设计为explicit,防止隐式转化的发生。...当然我们总可以为转化而显示的使用构造函数: trans1.same_isbn(Sales_item(null_book)); 版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。

37730

js 中的构造函数构造函数作用,构造函数和普通函数的区别

之所以有构造函数与普通函数之分,主要从功能上进行区别的,构造函数的主要 功能为 初始化对象,特点是和new 一起使用。new就是在创建对象,从无到有,构造函数就是在为初始化的对象添加属性和方法。...以上就是构造函数的整个执行过程。 3、用new和不用new调用构造函数,有什么区别? 1、用new调用构造函数函数内部会发生如下变化: 创建一个this变量,该变量指向一个空对象。...并且该对象继承函数的原型; 属性和方法被加入到this引用的对象中; 隐式返回this对象(如果没有显性返回其他对象) 简单的说 用new调用构造函数,最大特点为,this对象指向构造函数生成的对象...(ES6 中 class 与构造函数的关 系,通过class定义的类 和通过构造函数定义的类 二者本质相同。并且在js执行时,会将第一种转会为第二种执行。...所以 ES6 class的写法实质就是构造函数) 4、内部用this 来构造属性和方法 5、构造函数的执行流程 A、立刻在堆内存中创建一个新的对象 B、将新建的对象设置为函数中的this C、

3.4K10

js构造函数的理解

1、什么是构造函数 在 JavaScript 中,用 new 关键字来调用的函数,称为构造函数构造函数首字母一般大写 2、为什么要使用构造函数?...; this.hobby = hobby; this.age = 6; } 当创建上面的函数以后, 我们就可以通过 new 关键字调用,也就是通过构造函数来创建对象了。...此时你会发现,创建对象会变得非常方便。所以,虽然封装构造函数的过程会比较麻烦,但一旦封装成功,我们再创建对象就会变得非常轻松,这也是我们为什么要使用构造函数的原因。...在使用对象字面量创建一系列同一类型的对象时,这些对象可能具有一些相似的特征(属性)和行为(方法),此时会产生很多重复的代码,而使用构造函数就可以实现代码复用。...{ return "I am " + this.name; } // 返回this对象 return this; } 可以看出,用new调用构造函数,最大特点为,this对象指向构造函数生成的对象

2.1K31

【JavaScript】内置对象 - Date 日期对象 ① ( Date 对象简介 | 使用构造函数创建 Date 对象 | 构造函数参数为时间戳 | 构造函数参数为空 | 构造函数参数为字符串 )

, 如 : 获取当前日期和时间 设置日期和时间 比较日期和时间 等操作 ; 2、创建 Date 对象 Math 对象不需要手动调用构造函数 , 可以直接使用 ; Date 对象 只能 通过调用 Date...构造函数 进行实例化 , 调用 Date() 构造函数时 , 必须使用 new 操作符 进行调用 ; 创建的 Date 对象 , 可以用来创建日期和时间的实例 , 或者表示特定的时间点 ; 创建 Date...hours [, minutes [, seconds [, milliseconds]]]]]); 二、使用构造函数创建 Date 对象 1、构造函数参数为空 使用 new Date(); 构造函数...创建 Date 对象 , 该构造函数中没有参数 , 则会返回当前的时间 ; 代码示例 : // 创建 Date 内置对象 var date = new Date();...(date); 执行结果 ; 2、构造函数参数为时间戳 使用 new Date(value); 构造函数 创建 Date 对象 , 传入的参数是 一个 Unix 时间戳 Unix Time Stamp

18110

【Kotlin】Kotlin 构造函数 ( 主构造函数 | 主构造函数声明属性 | init 初始化代码块 | 次构造函数 | 构造函数委托 | 调用构造函数创建实例对象 )

构造函数 ( 常用情况 ) VII . 次构造函数 ( 没有主构造函数 ) VIII . 构造函数 代码执行顺序 IX . 调用 主构造函数 / 次构造函数 创建类实例对象 I ....代码执行顺序 : init 初始化代码块 , 与类的属性定义优先级相同 , 在类对象实例初始化时 , 会按照在类中定义的顺序 , 依次执行类属性初始化和 init 初始化代码块 ; 4 ....代码执行顺序示例 : 类对象初始化时 , 代码执行顺序是 : 代码 ① -> 代码 ② -> 代码 ③ -> 代码 ④ class Student constructor(name : String,...调用 主构造函数 / 次构造函数 创建类实例对象 ---- 1 ....创建实例对象 : Kotlin 中没有 new 关键字 , 使用 类名 ( 构造函数参数列表 ) 方式 , 创建类对象实例 ; 2 .

3.2K10

JS高级——构造函数和原型

概述 在典型的OOP的语言中(如Java),都存在类的概念,类就是对象的模板,对象就是类的实例,但在ES6之前,JS中并没有引入类的概念。...在JS中,使用构造函数要注意以下两点: 构造函数用于创建某一类对象,其首字母要大写。 构造函数要和new一起使用才有意义。...静态成员:在构造函数本身上添加的成员称为静态成员,只能由构造函数本身来访问。 实例成员:在构造函数内部创建的对象成员称为实例成员,只能由实例化的对象来访问。...构造函数原型prototype 构造函数通过原型分配的函数是所有对象所共享的。...一般情况下,对象的方法都在构造函数的原型对象中设置,通过构造函数无法继承父类方法。

1.4K10

JS高级」构造函数和原型

constructor 主要用于记录该对象引用于哪个构造函数,它可以让原型对象重新指向原来的构造函数。 一般情况下,对象的方法都在构造函数的原型对象中设置。...如果有多个对象的方法,我们可以给原型对象采取对象形式赋值,但是这样就会覆盖构造函数原型对象原来的内容,这样修改后的原型对象 constructor 就不再指向当前构造函数了。...__proto__属性,指向的构造函数的原型对象构造函数的原型对象也是一个对象,也有__proto__属性,这样一层一层往上找就形成了原型链。...1.8构造函数实例和原型对象三角关系 构造函数的prototype属性指向了构造函数原型对象; 实例对象是由构造函数创建的,实例对象的__proto__属性指向了构造函数的原型对象构造函数的原型对象的...this指向了对象o, 2.2子构造函数继承父构造函数中的属性 先定义一个父构造函数 再定义一个子构造函数构造函数继承父构造函数的属性(使用call方法) // 1.

1.5K50

第186天:js深入理解构造函数和原型对象

但在js中不存在类的概念,js不是基于类,而是通过构造函数(constructor)和原型链(propotype chains)实现的。...但在ES6中引入了类(class)这个概念,作为对象的模板,新的class写法知识让原型对象的写法更加清晰,这里不重点谈这个 2.首先我们来详细了解下什么是构造器   构造函数的特点:     a:构造函数的首字母必须大写...: 所有的实例对象都可以继承构造函数中的属性和方法。...所以,缺点就是:同一个构造函数对象实例之间无法共享属性和方法。   为了解决构造函数的这个缺点,js提供了prototype属相来解决该问题。   ...3.了解了构造器,我们来看下原型prototype   JS中万物都是对象,但是对象也分为:普通对象函数对象,也就是Object 和 Function.   那么怎么区分普通对象函数对象呢?

69320

PHP面向对象-构造函数和析构函数

构造函数构造函数是一种特殊的函数,用于在对象创建时初始化对象的属性。每当创建一个新对象时,PHP都会自动调用构造函数构造函数的名称必须与类名相同,并且可以带有参数。...在创建一个新的Person对象时,可以像这样调用构造函数:$person = new Person('John', 30);上述代码将创建一个名为$person的新Person对象,并将其$name属性设置为...请注意,构造函数在类中只能有一个,并且不能手动调用。它只能在创建新对象时自动调用。析构函数析构函数是另一种特殊的函数,用于在对象销毁时执行清理操作。当对象不再被使用时,PHP会自动调用析构函数。...与构造函数一样,析构函数的名称必须与类名相同,并且不带参数。...'; }}在上面的示例中,MyClass类包含一个构造函数和一个析构函数构造函数在创建对象时输出一条消息,而析构函数在销毁对象时输出另一条消息。

61220

C++|对象模型|合成构造函数

本文参考深度探索C++对象模型 编译器为未定义构造函数的类合成默认构造和拷贝构造函数 如果你已经开始点头了,那么你和我一样,陷入了深深的误解。 当我看到书中作者的这句话时,几乎是一身冷汗。...答案有四种 组合:成员定义了构造函数(memberwise) 继承:基类定义了构造函数函数 虚基类 本质上,12和34还有所不同。...在12中,编译器采取的方式是在合成出的构造函数中调用这些已经定义好的构造函数。 在34中,编译器需要对虚表指针和虚基类指针进行初始化操作....所以,空空如也的构造函数,在这种情况下,实际的代码量可能会让你惊讶。...拓展:POD Plain Ol' Data 对于所有合成函数为平凡,且不含虚机制的类(C style)编译器只产生平凡合成函数的声明,而不进行定义和调用。 除构造外的其他函数同理。

54830

【C++】类与对象构造函数、析构函数、拷贝构造函数、常引用)

构造函数 构造函数是一个特殊的成员函数,名字与类名相同,创建类类型对象时由编译器自动调用,在对象整个生命周期内只调用一次。...构造函数是特殊的成员函数,需要注意的是,构造函数虽然名称叫构造,但是构造函数的主要任务并不是开空间创建对象,而是初始化对象。 特性 函数名与类名相同。 无返回值。...(不是void,不需要写) 对象实例化时编译器自动调用对应的构造函数构造函数可以重载。 注意:如果通过无参构造函数创建对象时,对象后面不用跟括号,否则就成了函数声明。...析构函数 析构函数:与构造函数功能相反,析构函数不是完成对对象本身的销毁,局部对象销毁工作是由 编译器完成的。而对象在销毁时会自动调用析构函数,完成对象中资源的清理工作。...拷贝构造函数 拷贝构造函数:只有单个形参,该形参是对本类类型对象的引用(一般常用const修饰),在用已存 在的类类型对象创建新对象时由编译器自动调用。 特性 拷贝构造函数构造函数的一个重载形式。

13910

理解构造函数与原型对象

中已新增了类class的功能,越来越严格,越来越像后端语言,Es6,Es7新增的诸多方法也越来越强大,但是我觉得理解构造函数与原型对象还是有必要的,是js面向对象编程的基础,今天就我的学习和使用跟大家分享一下学习心得...,因为它默认会返回构造函数调用,当构造函数的调用执行时,会显示的返回返回) 什么是构造函数 定义:构造函数就是你用new关键字创建对象时调用的函数 作用(优点):创建多个共享特定属性和行为的对象,主要是用于生成对象的饼干模具...,在原型里,是原型链,构造函数与原型之间的连接就是原型链,当访问对象的某个属性时,js首先在自定义的属性的作用域内查找该变量是否存在,如果不存在,则会沿着原型链向原型下的查找该属性,直至顶层Object...,完成一简易的选项卡,其中jquery写法最为简单,容易懂,但是这里只是为了尝试用面向对象的思想去写应用,从普通的写法,也就是原生js写法,到面向对象写法,可以看出首先通过变形,把局部的功能给拎出来,封装成一个函数...,功能上与内置的函数并没有多大的区别,构造函数首字母大写用来区分普通函数还是构造函数,构造函数中的this指向该实例化的构造函数,主要是创建多个共享特定属性和行为的对象,用于创建模板,作为饼干工具,而原型对象主要是改写构造函数

1.1K40
领券