ホームページ >ウェブフロントエンド >jsチュートリアル >js は文字列と配列の間の変換操作を実装します
この記事ではJavaScriptにおける文字列と配列の相互変換方法を紹介し、皆さんの参考に共有します
文字列と配列の相互変換操作はよく使われるので非常に重要です。はい、これは習得する必要がある知識ポイントです。もちろん、一度知ってしまえば、それを習得するのに十分な練習が必要になるわけではありません。簡単な紹介です。
1. 文字列を配列に変換する
この操作では、指定された文字を区切り文字として使用して文字列を配列に変換することができる、split() 関数を使用します。出力結果 ご覧のとおり、split() 関数は文字列を配列に変換しました。
この操作は、Array オブジェクトの join() 関数を使用して実装できます。この関数は、配列内の要素を指定された文字で結合し、結果の文字列を返すことができます。
コードは次のとおりです:var Str="abc-mng-zhang-mayi"; var newArray=Str.split("-"); console.log(newArray);
3. カスタム文字列を配列に変換する
var newArray=["abc","mng","zhang","mayi"]; var Str=newArray.join("-"); console.log(Str);
上記のコードは、文字列を配列に変換する関数も実装しています。
1.function StringToArray(str, substr ){}、この関数は変換に使用されます。str は変換される文字列、substr は区切り文字です。
2. var arrTmp=new Array()、分割された文字列フラグメントを格納する配列を宣言します。3.if(substr=="") {arrTmp.push(str);return arrTmp;}、文字列区切り文字が空の場合、文字列全体が配列に入れられます。
4. var i=0,j=0,k=str.length; 3 つの変数を宣言し、k の値は文字列内の文字数を割り当てます。
5.while(i
7.if(j!=-1)、検索された区切り文字が存在する場合。
8.if(str.substring(i,j)!=""){}、検索開始位置から最初の区切り文字までの文字列をインターセプトします。
9.arrTmp.push(str.substring(i,j));、インターセプトした文字列を配列に入れます。
10.i=j+1; 検索の開始位置を区切り文字の次の文字に設定します。
11.else{}、検索がない場合。
12.if(str.substring(i,k)!=""){arrTmp.push(str.substring(i,k));}、最後の区切り文字の後の文字が空でない場合は、配列。
13.i=k、i を k に設定すると、ループが停止します。
14.return arrTmp; 配列を返します。
関連知識:
1. Push() メソッドの定義と使用法:
このメソッドは、指定された配列の末尾に 1 つ以上の新しい要素を追加し、配列の長さを返すことができます。
注: 新しい要素は、新しい配列を作成するのではなく、元の配列に直接追加されます。
クリックすると、配列のその他のプロパティとメソッドが表示されます。
構文構造:
arrayObject.push(要素 1、要素 2、....、要素 N)
パラメータ リスト:
パラメータの説明
パラメータ (1...N) が必要です。追加される新しい要素。
サンプルコード:
function StringToArray(str,substr) { var arrTmp=new Array(); if(substr=="") { arrTmp.push(str); return arrTmp; } var i=0,j=0,k=str.length; while(i<k) { j=str.indexOf(substr,i); if(j!=-1) { if(str.substring(i,j)!="") { arrTmp.push(str.substring(i,j)); } i = j+1; } else { if(str.substring(i,k)!="") { arrTmp.push(str.substring(i,k)); } i=k; } } return arrTmp; } var Str="abc-mng-zhang-mayi"; console.log(StringToArray(Str,"-")); console.log(StringToArray(Str,"-").length);
2.indexOf()メソッドの定義と使用法:
このメソッドは、指定された文字列が文字列内で最初に出現する位置を返します。対応する文字列が取得できなかった場合、戻り値は-1になります。
注: このメソッドでは大文字と小文字が区別されます。文法構造:
stringObject.indexOf(substring,startindex)
サンプルコード:
var a = [1,2,3]; console.log(a.push("zhang","dao"));
bは文字列abcdefgの2番目に表示されます。出力結果: 1.
var a=new String("abcdefg") console.log(a.indexOf("b"));
このメソッドでは大文字と小文字が区別されるため、文字列 abcdefg には大文字の B は含まれません。出力結果: -1。
var a=new String("abcdefg") console.log(a.indexOf("b"));
検索開始位置は4で、文字列の先頭から最初に出現する位置を計算します。出力結果:4.
3.substring() 関数。
4. カスタム配列を文字列に変換する
var a=new String("abcdefg") console.log(a.indexOf("e",4));
上記のコードは要件を実現しており、コードにコメントを付けてみましょう:
コードコメント:1.function ArrayToString(arr,str) {}、最初のパラメータは配列、2 番目のパラメータは接続文字列です。
2.var strTmp=""、空の文字列を宣言します。3.for(var i=0;i
5.if(strTmp=="") {strTmp=arr;}、文字列も空の場合は、配列内のこの要素を文字列 strTmp に割り当てます。
6.else{strTmp=strTmp+str+arr}、それ以外の場合は文字列連結を実行します。
7.return strTmp、変換された文字列を返します。
上記は、js で文字列と配列の間で変換するための詳細なコードです。皆さんの学習に役立つことを願っています。
文字列と配列の間の変換操作の js 実装に関連するその他の記事については、PHP 中国語 Web サイトに注目してください。