首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
您找到你想要的搜索结果了吗?
是的
没有找到

js---对象函数this

一:对象创建的方法  //普通 字面量形式 var obj = { name:'名字', fn:function(){ console.log(this.name);...obj的方法调用,所以函数体中的this就代表obj对象   2.函数调用模式 当一个函数并非一个对象的属性时,那么它就是被当做函数来调用的。...3.构造函数模式   如果在一个函数前面加上new关键字来调用,那么就会创建一个连接到该函数的prototype成员的新对象,同时,this会被绑定到这个新对象上。...,函数体内的this被绑定为新创建对象person。   ...4.apply调用模式 在JS中,函数也是对象,所有函数对象都有两个方法:apply和call,这两个方法可以让我们构建一个参数数组传递给调用函数,也允许我们改变this的值。

1.3K30

第163天:js面向对象-对象创建方式总结

面向对象-对象创建方式总结 1、 创建对象的方式,json方式 推荐使用的场合: 作为函数的参数,临时只用一次的场景。比如设置函数原型对象。...缺点: 不能作为对象创建的模板,也就是不能用new进行构造新对象。 2、 创建面向对象的方式: new Object()的方式。 不推荐使用。...(new后面的那个函数),在构 12 //造函数内部创建一个空对象, 13 // 第二步: 把上面的空对象跟构造函数的原型对象进行关联。...14 // 第三步:然后把this 指向当前空对象 15 //在构造函数执行结束后,把空对象返回 给 p 16 17 console.log( p.name ); //p.name 从构造函数里面创建的...升级改造版本: //第三种方式有个缺点: 对象的内部的函数会在每个对象中都存一份 //如果创建对象非常多的话,那么非常浪费内存。函数的行为是所有对象 //可以共有,不需要每个对象都保存一份。

1.7K10

构建函数(class)创建对象,对象属性新增和修改

class:利用函数方法创建对象,也称构建传说创建对象; 构建函数创建对象 function byd(){             this.color='象牙白';             this.pinpai...            };             this.runy=function(){                 alert('避雨');             }         } 构造函数创建对象的属性和方法修改...var bydcar=new byd();//创建一个对象bydcar,使用byd的属性 bydcar.color='黑耀黑';//修改属性 bydcar.run=function(){ alert(...'我很厉害')}//修改方法 构造函数创建对象的属性和方法新增 bydcar.length='2米';//新增属性 byd.money=function(){ alert('客运赚钱'); }//新增方法...构建函数创建对象类似函数,内部的属性方法用分号分离,json创建对象各类属性方法用逗号可开

1.2K20

浅谈 JS 创建对象的 8 种模式

,新建一个以这个原型模板为原型的对象 //上面6种都是一样 //区别 var o7 = Object.create(null);//创建一个原型为 null 的对象 2.工厂模式 //工厂方法1 通过一个方法来创建对象...();//在 JS 中没有传递的实参,实际形参值为 undefined(这里的 age 为 undefined) createCar("tim",80).showName(); alert(createCar...showDoor 方法版本(方法有自己的作用域,不用担心变量被共享) } alert(new Car("red",2).showColor());//通过构造器创建一个对象并调用其对象方法 4.通过...Function对象实现创建对象 我们知道每声明一个函数实际是创建了一个Function 实例 JS 函数. function function_name(param1,param2){alert(param1...new 运算符,所以将忽略第二个 new 运算符(位于构造函数之外), 在构造函数内部创建对象被传递回变量car6,这种方式在对象方法的内部管理方面与经典方式(工厂方法)有着相同的问题.应尽量避免

1.1K20

JS对象的简单创建和继承

对象的简单创建 1.通过对象直接量创建 比如 var obj = {}; 2.通过new 创建 比如 var obj = new Object(); // 相当于var obj = {};    var...); 对象的简单继承: 可以通过原型继承创建一个新对象 以下函数inherit() 返回一个继承自原型对象p的属性的新对象 function inherit(p){ if(p == null)...== "function"){ //要继承的对象 类型要符合 throw TypeError(); } function f(){ }; //定义一个空的构造函数...== "function"){ //要继承的对象 类型要符合 throw TypeError(); } function f(){ }; //定义一个空的构造函数...值得注意的是:它总是在原始对象创建属性或对已有的属性赋值,而不会去修改原型链;在JS中,只有在查询属性时才会体会到继承的存在,而设置属性则和继承无关。

2.8K20

vue-jsonp_js创建json数组对象

其中key值必须为字符串,value可以为字符串、数字、对象、数组、布尔型、null。但value不能为函数、日期和undefined值。...前后端分离开发中,后端返回的接口中的数据是json字符串格式,json字符串元素的属性或者说key值用双引号””,参考如下: 而前端需要处理成json对象格式,参考如下格式 二、JSON字符串和JSON...对象相互转换 1.如何将json字符串转换为json对象呢 通过JSON.parse() 方法 JSON.parse(字符串) //将该字符串转为json对象给前端使用 2.如何将json对象转换为json...字符串 通过JSON.stringify() 方法 JSON.stringify(json对象) //将json对象转换为json字符串,传给后端 版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人

6.7K20

JS学习笔记-OO创建怀疑的对象

问了、工厂介绍,解决重码 前面已经提到,JS创建对象的方法。不难发现,主要的创建方法中,创建一个对象还算简单,假设创建多个类似的对象的话就会产生大量反复的代码。...解决对象之间的共享问题 每个对象都会有一个prototype,同一时候它也是一个对象。 使用目的是为了解决共享问题,调用同一个构造函数创建的该对象会共享prototype中的属性和方法。...问四、使用组合,解决共享及传參 原型模式创建对象省略了构造函数传參初始化的过程,这既是它的缺点又是它的长处,缺点是对象初始化的值一样,而且假设原型属性中包括有引用类型,则对一个对象进行更改。...'; }; } } 中结: 在学习JS中,还是非常须要对正统面向对象语言的理解的,在这里我们学习了使用构造函数以及原型来创建对象...,理解了二者的概念,对于后面的JS中面向对象深入学习会非常有帮助。

2.5K30

重学js之JavaScript 面向对象的程序设计(创建对象

工厂模式 工厂模式:抽象了创建具体对象的过程。考虑到ES中无法创建类,于是就用一种特定的函数来封装以特定接口创建对象的细节。...另外如果要创建P实例,必须使用 new 操作符,以这种方式调用构造函数实际上会经历以下4个步骤: 创建一个新对象 将构造函数的作用域赋给新对象(因此 this 指向了这个新对象) 执行构造函数中的代码(...5.1 理解原型对象 无论什么时候,只要创建了一个新函数,就会根据一组特定的规则为该函数创建一个 prototype 属性, 这个属性指向函数的原型对象。...寄生构造函数模式 创建一个函数,该函数的作用仅仅是封装创建对象的代码,然后再返回新创建对象。...注意:寄生构造函数模式返回的对象与构造函数或者与构造函数的原型属性之间没有关系,也就是说,构造函数返回的对象与在构造函数外部创建对象没有什么不同。

1.5K30

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

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

1.2K10

前端学习(37)~js学习(十四):对象创建

构造函数 代码引入 // 创建一个构造函数,专门用来创建Person对象 function Person(name, age, gender) { this.name...,专门用来创建 Dog 对象 function Dog() {} var dog = new Dog(); 构造函数的概念 构造函数:是一种特殊的函数,主要用来创建和初始化对象...我们可以把对象中一些公共的属性和方法抽取出来,然后封装到这个构造函数里面。 构造函数和普通函数的区别 构造函数创建方式和普通函数没有区别,不同的是构造函数习惯上首字母大写。...比如fun();相当于window.fun(); 2.以方法的形式调用时,this是调用方法的那个对象 3.以构造函数的形式调用时,this是新创建的实例对象 new 一个构造函数的执行流程...类、实例 使用同一个构造函数创建对象,我们称为一类对象,也将一个构造函数称为一个类。 通过一个构造函数创建对象,称为该类的实例。

1.6K20
领券