JavaScript での Array.apply の解析

小云云
小云云オリジナル
2018-02-28 13:39:564103ブラウズ

まず質問を見てみましょう:

Array.apply(null, {length:5}) の {length:5} を理解するにはどうすればよいですか? この記事では主に JavaScript での Array.apply の分析について説明します。みんなを助けるために。

テストしてみました

Array.apply(null, {length:5}) //返回[undefined, undefined, undefined, undefined, undefined]
Array.apply(null, [{length:5}])和Array({length:5})返回的结果是一样的,为[[object Object] { length: 5 }]

2番目と3番目はまだ理解できます!最初のものをどうやって理解すればいいでしょうか?

実は、これは Array とは関係なく、Array を使用しているときにたまたま遭遇しただけです。

この問題は Function.call と Function.apply で解決されるべきだと思います。
これら 2 つの関数のメソッドは同じ機能を持ち、どちらも this のポインターを変更するために使用されます。
唯一の違いは、apply の 2 番目のパラメーターを配列で渡す必要があることです。

まず第一に、iAmArray を定義する関数が必要です。

var iAmArray = function(){
    return arguments;
};

ここでは心配する必要はありません。通常、それを呼び出す 3 つの方法があります:

//方便你复制到 Console 中测试,在此再写一遍
var iAmArray = function(){
    return arguments;
};

//普通写法
iAmArray(1,2,3);
/*
    [1, 2, 3]
*/

//call写法
iAmArray.call(null,1,2,3);
/*
    [1, 2, 3]
*/

//apply写法
iAmArray.apply(null,[1,2,3]);
/*
    [1, 2, 3]
*/

適用モードで呼び出される場合は、次のようになります。おそらく小さなバグですが、オブジェクトである限り、配列として扱われる長さも存在します。これは実際には配列とは何の関係もありません。

//方便你复制到 Console 中测试,在此再写一遍
var iAmArray = function(){
    return arguments;
};

var iHaveLength = function(length){
    this.length = length || 5;
    this[2] = "第三个元素";
};

/*
   只要是 Object,还有length,他就当作数组处理了。
*/
iAmArray.apply(null, new iHaveLength());
/*
    [undefined, undefined, "第三个元素", undefined, undefined]
*/
iAmArray.apply(null, new iHaveLength(3));
/*
    [undefined, undefined, "第三个元素"]
*/

最終まとめ

実際、2 番目のパラメータは、{length: 5} などの配列のようなオブジェクトにするだけでよく、これは長さ 5 の配列のようなオブジェクトとみなすことができます。 、v[ 0] などの各要素は未定義です。

つまり、Array.apply(null, { length: 5}) は
Array(未定義, 未定義, 未定義, 未定義, 未定義) と同等です


以上がJavaScript での Array.apply の解析の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。