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

js---对象函数this

当一个方法被调用时,this被绑定到这个对象上。如果调用表达式包含一个提取属性的动作(. 或 []),那么它被称为方法调用。...obj的方法调用,所以函数体中的this就代表obj对象   2.函数调用模式 当一个函数并非一个对象的属性时,那么它就是被当做函数调用的。...3.构造函数模式   如果在一个函数前面加上new关键字来调用,那么就会创建一个连接到该函数的prototype成员的新对象,同时,this会被绑定到这个新对象上。...这种情况下,这个函数就可以成为此对象的构造函数。...4.apply调用模式 在JS中,函数也是对象,所有函数对象都有两个方法:apply和call,这两个方法可以让我们构建一个参数数组传递给调用函数,也允许我们改变this的值。

1.3K30

【JavaScript】对象 ② ( 对象使用 | 调用对象属性 | 调用对象方法 | 变量与属性区别 | 函数与方法区别 )

() { console.log(this.name + " is " + this.age + " years old"); } }; 2、调用对象属性 调用对象属性...(person['name']); 执行结果 : 3、调用对象方法 调用对象方法 : 使用 对象名.方法名(...) 的方式 , 调用对象方法 ; // 调用对象方法 - 对象名.方法名() person.hello(); 完整代码示例 : <!..., 不需要声明 , 但是在使用时 , 必须 用 对象名.属性名 或者 对象名[属性名] 的方式使用 ; 三、函数与方法区别 函数与方法相同点 : 都可以 实现 某种功能 , 做某件事 ; 函数与方法不同点...: 函数 可以 单独声明存在 , 可以使用 函数名() 单独使用 ; 方法 在 对象中 , 不需要声明 , 但是在使用时 , 必须 用 对象名.方法名() 的方式使用 ;

9110

Js 使用new关键字调用函数和直接调用函数的区别

最近开始学习js,在看到书上的一个例子时,引发了我的一系列思考: 书上例子: function Person(name,age,job){ var o =new Object();...,并以相应的属性和方法初始化该对象,然后又返回了这个对象,除了使用new操作符且把使用的包装函数叫做构造函数之外,这个模式跟工厂模式是一模一样的。...person.sayName(); 得出结论:使用new关键字是将函数当作构造函数调用,即为构造对象,若没有人为的重写调用构造函数时返回的值,那么返回的对象是由解析器自己生成的。...不使用new关键字调用函数,即为普通函数调用。 随即想到若是函数返回值是function型的呢?...),虽然new函数与直接调用函数产生的结果等同,但是是两个不同的过程,一个是构造对象、一个是函数调用

3.6K10

js匿名函数和命名函数_jsp调用java方法

由衷的感叹,js真是烦。 学到现在,渐渐理解了什么是:语言都是通用的,没有好不好,只有擅长不擅长。...温故知新,今天又回味了一遍,匿名函数作为函数参数。 代码很短,五脏俱全。...难道匿名函数自执行了? 错!!!匿名函数!=自执行匿名函数 真相只有1个:匿名函数作为参数,在调用(将匿名函数作为参数的)函数里被调用执行了。...function test( a, b ){ a+=1; // b是对象函数名也是对象,所以b可以指代一个函数 // 类似c++中的函数名一样 // a被复制给了b(result) // js好灵活...b(a); } 以上这篇js匿名函数作为函数参数详解就是小编分享给大家的全部内容了,希望能给大家一个参考。

6.2K20

JavaScript 的 this 小结纯粹的函数调用作为对象方法的调用作为构造函数调用apply 调用

它是函数运行时,在函数体内部自动生成的一个对象,只能在函数体内部使用。 ? 上面代码中,函数test运行时,内部会自动有一个this对象可以使用。 那么,this的值是什么呢?...函数的不同使用场合,this有不同的值。 总的来说,this就是函数运行时所在的环境对象。 下面分情况,详细讨论 纯粹的函数调用 函数的最通常用法,属全局性调用,this即代表全局对象。 ?...运行结果是1 作为对象方法的调用 函数还可以作为某个对象的方法调用,这时this就指这个上级对象 ? 结果:1 作为构造函数调用 通过这个函数,可以生成一个新对象。this就指这个新对象。 ?...运行结果为1 为了表明这时this不是全局对象,我们对代码做一些改变: ? 运行结果为2,表明全局变量x的值根本没变。 apply 调用 apply()是函数的一个方法,作用是改变函数调用对象。...它的第一个参数就表示改变后的调用这个函数对象。因此,这时this指的就是这第一个参数。 ? apply()的参数为空时,默认调用全局对象。因此,这时的运行结果为0,证明this指的是全局对象

2.6K20

JAVA & .NET创建对象构造函数调用顺序

chinese init block chinese init block2 chinese constructor 执行顺序为: 基类静态初始化块——当前类静态初始化块——基类初始化块——基类构造函数...——当前类初始化块——当前类构造函数 ⚠️ JAVA中加载类时会调用类的静态代码块 try { Class.forName("models.Chinese"); } catch (ClassNotFoundException...} ​ static Chinese() { Console.WriteLine("chinese static constructor"); } } ​ 创建对象...——基类静态构造函数——基类构造函数——当前类构造函数 小结 JAVA与.NET创建对象时都是先执行静态代码块后执行非静态代码块; JAVA先执行基类中的静态及非静态代码块; .NET先执行基类中的静态代码块...,先执行当前类中的实例构造函数

1.1K20

JS 匿名函数——几种不同的调用方式

声明:var func=function(){ } 调用:func(); var show = function(){ alert('hello'); }; show(); 注意:使用匿名函数表达式时...,函数调用语句,必须放在函数声明语句之后!!!...原因:检查装载时,会先对show变量及这个匿名函数声明,此时,还未将匿名函数赋值给show变量,如果在表达式之前调用,会报错 show is not a function js代码的执行顺序问题 js...检查装载阶段:会先检测代码的语法错误,进行变量、函数的声明 执行阶段:变量的赋值、函数调用等,都属于执行阶段。 3.自执行函数。这里我总结了8种常用的匿名函数调用方法: //1.使用 !...(function(){ document.write('wo hao'); })(); //3.能够将匿名函数调用的()为一个整体,官方推荐使用; (function(){ document.write

3.9K10

实战C++对象模型之成员函数调用

通过本文的演示,可以看见这背后的一切,完全可C函数方式调用C++类普通成员函数和C++类虚拟成员函数。 为了实现C函数方式调用C++类成员函数,准备两个文件:。...; }; void X::xxx() // bbb.cpp完全以C函数方式调用类X的成员函数xxx { printf("m=%d, n=%d\n", m, n); } 把aaa.cpp编译成共享库:...(1); } // 第1组测试数据 struct X x1; x1.m = 19; x1.n = 18; (*xxx)(&x1); // 这里完全以C函数方式调用类X的类成员函数xxx // 第2组测试数据...struct X x2; x2.m = 2019; x2.n = 2018; (*xxx)(&x2); // 这里完全以C函数方式调用类X的类成员函数xxx // 第3组测试数据 x2.m = 29;...x2.n = 28; (*xxx)(&x2); // 这里完全以C函数方式调用类X的类成员函数xxx return 0; } 把bbb.cpp编译成可执行程序: $ g++ -g -o bbb

98510

让类成员函数指针成为可调用对象

类成员函数指针实践上是一个指针类型,不可直接通过调用运算符()作为可调用对象调用,一般调用该类成员函数指针需要指定该指针对应的对象。     ...在可调用对象里有接收对象对象指针的一组调用运算符重载函数,可使用对象对象指针调用该成员函数,使用方式与function相同: // main.cpp,头文件a.h与源文件a.cpp之前相同 #... // mem_fn通过成员函数指针自动推导可调用对象类型     fnt(a); // 使用对象调用成员函数     fnt(&a); // 使用对象指针调用成员函数     return 0; }...类似,生成的可调用对象有接收对象对象指针的一组重载调用运算符函数: // main.cpp,头文件a.h与源文件a.cpp之前相同 #include  #include "a.h... 使用对象调用成员函数     fnt(&a); // 使用对象指针调用成员函数     return 0; } 详细说明可查阅bind函数,fnt(a)与fnt(&a)的结果一致。

1K40

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

js函数对象关系快速记忆

js中关于原型和原型链有 __proto__ 、prototype、constructor 频频出现在面试题中,但是记得多了反而容易记混。 这里简单总结下每个属性的使用场景,方便记忆。...对象函数都有 __proto__,对象的 __proto__指向构造函数的prototype,构造函数的__proto__指向 Function.prototype 对象函数都有constructor...,对象的 constructor指向构造函数,构造函数的constructor指向 Function 函数才有 prototype 函数的prototype又是一个对象,但是 Funtion.prototype...特殊记忆:typeof Function.prototype==="function" Object因为O大写,可以看出本质也是一个构造函数 __proto__ 指向一个原型对象,构造函数.prototype...__proto__===null,因为 Object.prototype 为js 原型链的顶端。

69530
领券