Javascript面向对象--创建对象.构造函数的原型 其实:JavaScript中的创建类,就是创建一个构造函数,在创建对象时用到new这个关键字, 一.创建对象 1.函数创建对象 function creatObj(name,age){ //手动创建一个对象 var obj={} //为对象添加属性 obj.name=name obj.age=age obj.sayHi=function(){ console.log("hello world!") } //返回对象 return…
类.构造函数.原型  :本质均为函数 利用的原理是:词法作用域,调用对象及作用域链  闭包  属性查找方式    设计和new运算符一起使用的函数叫做构造函数. 构造函数的工作:初始化一个新创建的对象,设置在使用对象前需要设置的所有属性.   注:new创建一个新的没有任何属性的对象,然后调用该函数(调用对象),把此对象作为this关键字的值 传递给构造函数. 构造函数通常是没有返回值,只是为这个this设置属性,但一个构造函数是允许返回一个对象值的, 且如果这么做,返回的对象成为new表达式的…
JavaScript中的原型! 原型的内容是涉及到JavaScript中的构造函数的 每一个构造函数都有一个原型对象!prototype 他的作用是 共享方法!还可以扩展内置对象[对原来的内置对象进行扩展自定义的方法!] 每一个实例化的对象都有一个对象原型__proto__ 他指向的是构造函数的原型对象 所以我们创建的实例对象可以使用对象原型中的方法! __proto__对象原型和原型对象prototype是等价的 __proto__对象原型的意义就在于为对象的查找机制提供一个方向,或者说一条路…
纯属个人理解,有错误的地方希望大牛指出,以免误人子弟 1.构造函数: 构造函数的作用 : 初始化由new创建出来的对象    new 的作用: 创建对象(空对象) new 后面跟的是函数调用,使用new来调用函数,跟普通的直接调用函数主要的不同: 就是 this 的指向不同了 , 再就是 会自动的返回新创建的对象 什么是原型?        原型的作用:就是为了实现继承!  一个对象的原型就是它的构造函数的prototype属性的值. 在讨论原型的时候,是指的 对象和原型对关系 prototyp…
函数 函数是JavaScript中特殊的对象,对函数执行typeof运算会返回字符串"function",因为函数也是对象,他们可以拥有属性和方法. 静态方法 函数在JS中定义了类的名字,任何添加到函数的属性都是类字段和类方法(类比Java中类的static variable 和 static method),下面代码起到Java里面static method的效果: var foo = function(){}; foo.printLog = function(){ if (argu…
1.在典型的oop的语言中,如java,都存在类的概念,类就是对象的模板,对象就是类的实例.但在js中不存在类的概念,js不是基于类,而是通过构造函数(constructor)和原型链(propotype chains)实现的.但在ES6中引入了类(class)这个概念,作为对象的模板,新的class写法知识让原型对象的写法更加清晰,这里不重点谈这个 2.首先我们来详细了解下什么是构造器 构造函数的特点: a:构造函数的首字母必须大写,用来区分于普通函数 b:内部使用的this对象,来指向即将要…
1.初级创建对象 var oCar=new Object; oCar.color='red'; oCar.door=4; oCar.map=3; oCar.showColor=function () { // body... alert(this.color); } console.log(oCar); 缺点:需要创建多个Car实例 2.工厂函数创建对象 function showColor(){ alert(this.color) } function createCar(sColor,iDo…
在 JS 中,函数本身也是一个包含了方法(如apply和call)和属性(如length和constructor)的对象,而prototype也是函数对象的一个属性 function f(){} f.constructor //function Function(){[native code]} 可为prototype对象赋予属性和方法,只有当f作为构造器使用时,这些属性才会起作用 添加属性和方法除了在构造函数中,还可通过prototype属性来增加该构造器所能提供的功能 function Sn…
第5章 原型 5.1 原型属性 function f(a,b){ return a*b; }; // length 属性 f.length; // constructor 构造属性 f.constructor; // function Function() { [native code] } // prototype 属性 初始值是空对象 typeof f.prototype; //"object" 5.1.1 利用原型添加方法和属性 function f1(name,color){…
详细介绍:深入理解javascript原型和闭包(5)——instanceof 图片来源:https://www.ibm.com/developerworks/cn/web/1306_jiangjj_jsinstanceof/figure1.jpg…