JSにおける配列Arrayの操作方法を解説する例_基礎知識

WBOY
リリース: 2016-05-16 16:49:05
オリジナル
1293 人が閲覧しました

js の配列要素の追加と削除はいつも混乱していましたが、今日ようやく詳細な情報を見つけました。まず、テスト用のコードを教えてください。^-^

コピー。コード コードは次のとおりです:

var arr = new Array();
arr[0] = "aaa";
arr[ 1] = " bbb";
arr[2] = "ccc";
//alert(arr.length);//3
arr.pop();
//alert( arr.length) ;//2
//alert(arr[arr.length-1]);//bbb
arr.pop();
//alert(arr[arr.length-1] 1]); //aaa
//alert(arr.length);//1

var arr2 = new Array();
//alert(arr2.length);//0
arr2[0] = "aaa";
arr2[1] = "bbb";
//alert(arr2.length);//2
arr2.pop();
//alert(arr2.length);//1
arr2 = arr2.slice(0, arr2.length-1);
//alert(arr2.length);//0
arr2[0] = "aaa";
arr2[1] = "bbb";
arr2 [2] = "ccc";
arr2 = arr2.slice(0,1);
alert(arr2.length);//1
alert(arr2[0]);//aaa
alert(arr2[1]);//未定義

shift: 元の配列の最初の項目を削除し、削除された要素の値を返します。配列が空の場合は、unknown
var a = [1,2,3,4,5];var b = a.shift(); //a:[2,3,4,5] b:1

unshift: 元の配列の先頭にパラメータを追加し、配列の長さを返します。

var a = [1,2,3,4,5];
var b = a.unshift(- 2,- 1); //a: [-2,-1,1,2,3,4,5] b: 7
注: IE6.0 ではテストの戻り値は常に未定義であり、 FF2.0 での戻り値 値は 7 であるため、このメソッドの戻り値は信頼できません。戻り値を使用する必要がある場合は、このメソッドの代わりに splice を使用できます。

pop: 元の配列の最後の項目を削除し、削除された要素の値を返します。配列が空の場合は、未定義を返します

var a = [1,2,3,4,5];
var b = a.pop(); //a:[1,2,3,4] b:5//返す必要がない場合は直接呼び出してください

push: 元の配列の末尾にパラメータを追加し、配列の長さを返します。

var a = [1,2,3,4,5];
var b = a.push(6) ,7) ; //a:[1,2,3,4,5,6,7] b:7

concat: 元の配列にパラメータを追加して形成された新しい配列を返します。

var a = [1,2,3,4,5];
var b = a.concat(6) , 7); //a:[1,2,3,4,5] b:[1,2,3,4,5,6,7]

splice(start,deleteCount,val1,val2,...): 開始位置から deleteCount 項目を削除し、val1, val2,...を挿入します

配列をクリアするときは、startIndex を渡すだけです。

すべての要素を削除したくない場合は、deleteCount パラメータを再度渡します。

splice には、最初に削除してから追加する機能もあります。つまり、最初にいくつかの要素を削除し、次に削除された位置にいくつかの要素を追加します。削除された要素と追加された要素の数は同じである必要はありません。この時に使用されます。

var a = [1,2,3,4,5];
var b = a.splice(2,2,7,8,9); //a:[1,2,7, 8,9,5] b:[3,4]
var b = a.splice(0,1) //shift
a.splice(0,0,-2,-1)と同じ; var b = a.length;//unshift
var b = a.splice(a.length-1,1)と同じ;//pop
a.splice(a.length,0, 6,7 ); var b = a.length; //push
と同じ

reverse: 配列を反転します。

var a = [1,2,3,4,5];
var b = a.reverse(); //a: [5,4,3, 2] ,1] b:[5,4,3,2,1]

sort(orderfunction): 指定されたパラメーターに従って配列を並べ替えます

var a = [1,2,3,4,5];
var b = a.sort(); //a: [1,2,3,4,5] b:[1,2,3,4,5]

slice(start,end): 元の配列内の指定された開始インデックスから終了インデックスまでの項目で構成される新しい配列を返します

var a = [1,2,3,4,5];
var b = a.slice(2,5); //a:[1,2,3,4,5] b:[3,4,5]

join(separator): separator を区切り文字として使用して、配列の要素を文字列に結合します。省略した場合、デフォルトのカンマが区切り文字として使用されます。

var a = [1,2,3,4, 5 ];
var b = a.join("|") //a:[1,2,3,4,5] b:"1|2|3|4|5"

配列を使用して javaStringBuffer をシミュレートして文字列を処理する別の方法を教えてください:

/**

* 文字列処理関数
*/
function StringBuffer() {
var arr = new Array;
this.append = function(str) {
arr[arr.length] = str;
};

this.toString = function() {

return arr.join("");//追加された配列を文字列に ping します
};
}

今日、アプリケーションで配列を文字列に変換するには結合が良い方法であることを突然発見したので、それをオブジェクトにカプセル化して使用しました。

/**

*配列を特定の記号で区切られた文字列に変換します
*/
function arrayToString(arr,separator) {
if(!separator) separator = "";//セパレータが null の場合、デフォルトは空です
Return arr.結合(区切り文字);
}

/**

* 配列に含まれる文字列を検索します
*/
function arrayFindString(arr,string) {
var str = arr.join("");
return str.indexOf(string);
}

関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート