當前位置:
首頁 >
前端技术
> javascript
>内容正文
javascript
javascript中的call()和apply()方法 - 原创实例
生活随笔
收集整理的這篇文章主要介紹了
javascript中的call()和apply()方法 - 原创实例
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
?
1、方法定義
?
call方法: 語法:call([thisObj,arg1, arg2,arg……n]) ,參數arg只能為列表的形式,如:a,b,c 定義:調用一個對象的一個方法,以另一個對象替換當前對象。 說明: call 方法可以用來代替另一個對象調用一個方法。call 方法可將一個函數的對象上下文從初始的上下文改變為由 thisObj 指定的新對象。 如果沒有提供 thisObj 參數,那么 Global 對象被用作 thisObj。 apply方法: 語法:apply([thisObj,[argArray,arguments]]) ,參數age只能為數組或arguments的形式,如:[a,b,c]或arguments 定義:應用某一對象的一個方法,用另一個對象替換當前對象。 說明: 如果 argArray 不是一個有效的數組或者不是 arguments 對象,那么將導致一個 TypeError。 如果沒有提供 argArray 和 thisObj 任何一個參數,那么 Global 對象將被用作 thisObj, 并且無法被傳遞任何參數。?
?
?
2、常用實例
?
function User(name,age){//定義一個User方法this.name = function () { alert(name) }; ;this.age = function () { alert(age) }; }function CallUser(name, age) {//為CallUser方法,添加成員User.call(this, name, age); //如果用apply則為:User.apply(this, [name, age]); //User.call指來添加到this的對象,this指當前對象,當然這里的this也可以換成其它對象。后面的name,age分別指User函數的實參。 //這里的call相當于CallUser.protype=new User(); }var us = new CallUser("Sn", 20); //實參"Sn",20傳給CallUser函數。CallUser的name,age再傳給User函數 us.name();//Snus.age();//20?3、apply與protype結合使用
?
var Class = { //創建Class對象(字面量)app: function () { //創建一個名為app類(Function)return function() {this.init.apply(this, arguments); //當前this為function,繼承于init屬性,參數為arguments }}}var pro = Class.app(); // 創建一個名為pro類,些類被Class.app()賦值,(Function) pro.prototype = {init: function (arget) { // 定義pro類下的一個成員init,此成員用于實現Class類的initthis.arget = arget;},fn:function(){alert(this.arget);}}var obj = new pro("apply與protype結合使用");obj.fn(); //結果:apply與protype結合使用?
?附件下載
創作挑戰賽新人創作獎勵來咯,堅持創作打卡瓜分現金大獎總結
以上是生活随笔為你收集整理的javascript中的call()和apply()方法 - 原创实例的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 这个算是编码的坏习惯吧?
- 下一篇: 搭建主DNS服务器