国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

js 關于function 的所有疑惑點

loonggg / 3392人閱讀

摘要:但是引用對象保存的是,指針地址,所以傳入的也是指針地址。詳細解釋下傳參過程調用的時候,會進行參數的值傳遞。函數則是,如上。我們可以通過這樣就可以應用下的所有方法了。也就是說,在沒有傳入參數的時候,通過可以讓我們的擁有其他的方法

function 值傳遞

解決:什么時候什么樣的參數傳遞,會修改外部參數。
1.參數傳入function的過程,是一個值復制的過程。但是引用對象(object array function)保存的是,指針地址,所以傳入的也是指針地址。這樣,內存中就保持了兩個相同的地址,指向同一個對象。

詳細解釋下:function 傳參過程
function change(config){
  config.name = "changed" 
}

var obj = {name:"unchanged"}
change(obj);

調用function的時候,會進行參數的值傳遞。
obj = 一個對象嗎?錯,是對象在堆里的內存地址,
config = obj,是把對象的內存地址復制給config。這樣config和obj指向同一個對象,config可以修改外部對象了
var obj1 = {
    value:"111"
};

var obj2 = {
      value:"222"
};

function changeStuff(obj){
      obj.value = "333";
      obj = obj2;
      return obj.value;
}

var foo = changeStuff(obj1);

console.log(foo);// "222" 參數obj指向了新的對象obj2
console.log(obj1.value);//333

理解了這個,就理解了function里的傳值了
參考文獻:
解釋的超級清楚: http://fehacker.com/2014/12/19/call-by-sharing/

apply&call:修改function執行時,this指針對象

首先貼上api:https://developer.mozilla.org/zh-CN/docs/Web/JavaScript/Reference/Global_Objects/Function/apply#apply_and_built-in_functions
mdn官方文檔

fn.apply(thisObj,[argumentsArr]),apply的第二個參數是數組(或者類數組)。apply首先會修改function里的this指針,接著把[argumentsArr]數組里的參數一個一個 push fn。
fn.call(thisObj,name,age),call函數則是,如上。

當我們擁有可以改變this指針的fn時候,我們可以做什么呢?

利用apply push arguments的特點,可以解決目標函數只接受傳遞n個參數,而不是數組的時候

尋找數組最大值
var number = [2,34,43,5,6,6]
Math.max(2,34,43,5,6,6)//因為max方法,不接受數組參數

Math.max.apply(null,number)//

當一個obj沒有某個方法,但是其他對象實現了,就可以借助call使用

用的比較多的,通過document.getElementsByTagName選擇的dom 節點是一種類似array的array。
它不能應用Array下的push,pop等方法。我們可以通過:
var domNodes =  Array.prototype.slice.call(document.getElementsByTagName("*"));
這樣domNodes就可以應用Array下的所有方法了。

也就是說,在沒有傳入參數的時候,通過call可以讓我們的obj擁有其他obj的方法

文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。

轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/78305.html

相關文章

  • 關于javascript中類型判斷那些疑惑

    摘要:對于復雜類型它的每個實例都有屬性。當檢測實例時優于因為能檢測這段代碼是從的。補充以下結果,發現第三種方法也能正確判斷出。我們知道結果是那如何判斷兩個變量呢比較兩個變量,使用的即可。 Javascript中數據類型分為兩種: 簡單數據類型:Undefined, NULL, Boolean, Number, String 復雜數據類型:Object 接下來我們就來看看怎么做數據類型判別...

    李增田 評論0 收藏0
  • DOM疑惑整理(二)內聯、嵌入、外聯樣式訪問

    摘要:內聯樣式外聯樣式樣式屬性,寫在外部文件,通過鏈接導入。內聯樣式注意點樣式的應用,采取就近原則,因此一般情況優先級是內聯樣式嵌入樣式外聯樣式。中有新的方式去查看完整的屬性某元素內聯外聯嵌入樣式合起來計算后的屬性。 訪問的style屬性為空? 有時候,直接通過某元素的style屬性去查看相關信息時,會發現查看到的是空的屬性。原因很簡單,style屬性只能訪問內聯樣式,而你把css寫在了外部...

    Lucky_Boy 評論0 收藏0
  • 關于VUE響應式數據最佳解釋

    摘要:遍歷執行其中存儲的所有的匿名函數。如果我們使用一個類來管理相關依賴,這很接近的表現方式代碼看起來就像下面這樣你會發現現在匿名函數被儲存在而不是原來的。 許多前端框架(如Angular,React,Vue)都有自己的響應式引擎。通過理解如何響應,提議提升你的開發能力并能夠更高效地使用JS框架。本文中構建的響應邏輯與Vue的源碼是一毛一樣的! 響應系統 初見時,你會驚訝與Vue的響應系統。...

    endiat 評論0 收藏0
  • 探秘JS異步單線程

    摘要:對于通常的特別是那些具備并行計算多線程背景知識的來講,的異步處理著實稱得上詭異。而這個詭異從結果上講,是由的單線程這個特性所導致的。的特性之一是單線程,也即是從頭到尾,都在同一根線程下運行。而這兩者的不同,便在于單線程和多線程上。 對于通常的developer(特別是那些具備并行計算/多線程背景知識的developer)來講,js的異步處理著實稱得上詭異。而這個詭異從結果上講,是由js...

    cooxer 評論0 收藏0

發表評論

0條評論

最新活動
閱讀需要支付1元查看
<