javascript中字元串和數組的相互轉換

来源:http://www.cnblogs.com/zhadanren/archive/2016/01/11/5122514.html
-Advertisement-
Play Games

javascript中字元串和數組的相互轉換:字元串和數組的相互轉換操作是非常的重要的,因為在實際編碼過程中會經常用到,所以這是必須要掌握的知識點,當然這個知識點並不難,知道了就永遠知道了,並不是那種需要充分實踐才能夠掌握的東西,下麵就做一下簡單的介紹。一.字元串轉換為數組:此操作會用到split(...


javascript中字元串和數組的相互轉換:
字元串和數組的相互轉換操作是非常的重要的,因為在實際編碼過程中會經常用到,所以這是必須要掌握的知識點,當然這個知識點並不難,知道了就永遠知道了,並不是那種需要充分實踐才能夠掌握的東西,下麵就做一下簡單的介紹。
一.字元串轉換為數組:
此操作會用到split()函數,它能夠以指定的字元作為分隔符,將字元串轉換成一個數組,實例代碼如下:

 

var Str="abc-mng-zhang-mayi";
var newArray=Str.split("-");
console.log(newArray);

 

由輸出的結果可以看出,split()函數已經將字元串轉換成一個數組。
二.將數組轉換為字元串:
此操作可以使用Array對象的join()函數來實現,此函數可以將數組中的元素以指定的字元連接起來,然後返回產生的字元串。
代碼如下:

 

var newArray=["abc","mng","zhang","mayi"];
var Str=newArray.join("-");
console.log(Str);

 

以上代碼實現了我們的要求,使用"-"將數組元素連接了起來,並生成了一個字元串。
split()函數可以參閱JavaScript的String對象的split()方法一章節。 
join()函數可以參閱javascript的Array對象的join()方法一章節。 
上面的兩個例子都是使用的自帶的函數,當然我們也可以自己寫,這樣靈活性更大,並且知根知底。
三.自定義字元串轉換為數組:

 

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);

 

以上代碼同樣實現了將字元串轉換為數組的功能,下麵對代碼進行一下註釋:
代碼註釋:
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;聲明三個變數,並賦初值,k的值是字元串中字元的個數。
5.while(i<k){},一個while迴圈語句,執行的條件是i的值小於k也就是小於字元串中字元的個數。
6.j=str.indexOf(substr,i),用來檢測分隔符在字元串出現的位置,如果indexOf()函數帶有兩個參數的,第二個參數是查找指定字元開始的位置,這段代碼要結合下麵的代碼理解。
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()函數可以參閱javascript的Array對象的push()方法一章節。
2.indexOf()函數可以參閱javascript的String對象的indexOf()方法一章節。 
3.substring()函數可以參閱javascript的String對象的substring()方法一章節。
四.自定義數組轉換為字元串:

 

function ArrayToString(arr,str) 
{ 
  var strTmp=""; 
  for(var i=0;i<arr.length;i++) 
  { 
    if(arr[i]!="") 
    { 
      if(strTmp=="") 
      { 
        strTmp = arr[i]; 
      } 
      else
      { 
        strTmp=strTmp+str+arr[i]; 
      } 
    } 
  } 
  return strTmp; 
}
var newArray=["abc","mng","zhang","mayi"]; 
console.log(ArrayToString(newArray,"-"));

 

以上代碼實現了我們的要求,可以將數組轉換為字元串,下麵對代碼進行一下註釋:
代碼註釋:
1.function ArrayToString(arr,str){},第一個參數是數組,第二個參數是連接字元串。
2.var strTmp="",聲明一個空字元串。
3.for(var i=0;i<arr.length;i++) {},遍曆數組中的每一個元素。
4.f(arr!=""){}如果數組元素不為空。
5.if(strTmp=="") {strTmp=arr;},如果字元串中也為空,那麼就將數組中的此元素賦值給字元串strTmp。
6.else{strTmp=strTmp+str+arr},否則進行字元串連接。
7.return strTmp,返迴轉換後的字元串。

原文地址是:http://www.softwhy.com/forum.php?mod=viewthread&tid=9405

更多內容可以參閱:http://www.softwhy.com/javascript/

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • css設置span元素的尺寸:在預設狀態下是無法設置span元素的尺寸的,只能夠根據內容的尺寸自適應,也就是說給span元素設置width和height屬性預設條件是無效的。之所以會出現這種情況是因為span元素是內聯元素,內聯元素無法設置尺寸的,只要設置為塊級或者內聯塊級元素即可。代碼實例如下: ...
  • 如何利用jquery.1.9版本判斷瀏覽器的版本類型:在jquery.1.9以前的版本,可以使用$.browser很輕鬆的判斷瀏覽器的類型和版本,但是在1.9中和以後的版本中,$.browser已經被刪除,下麵就介紹一下如何實現此功能,希望能夠給需要的朋友帶來幫助。一.自定義代碼:$.browser...
  • 點擊文本框清除預設文本離開再恢復:很多網站的需要填寫的文本框在預設狀態下都會給出一個預設的提示語言,當滑鼠點擊此文本框的時候能夠將裡面的預設文本清除,當刪除輸入的文本且焦點離開文本框的時候再將預設的文本寫入文本框。代碼如下:點擊文本框清除預設值-螞蟻部落以上代碼實現了我們的要求,當點擊文本框的時候能...
  • 與換行相關的css屬性簡單介紹:在css佈局中可能需要人為的進行操作是否換行,如何換行,本章節就就做一下簡單介紹。一.word-break屬性:此屬性用來設定文本如何進行換行。語法結構:word-break:normal | break-all | keep-all參數解析:1.normal:預設值...
  • 滑鼠懸浮於鏈接之上出現文字說明效果:對於超鏈接標簽,有一個title屬性,當滑鼠表懸浮於鏈接之上時候,就會顯示title的屬性值,雖然在一定程度上滿足了我們的需要,但是美觀度卻似差強人意,同時無法修改它的樣式,下麵就來介紹一下如何利用jquery模擬實現此功能。代碼如下:螞蟻部落 螞蟻部落 ...
  • 網頁右下角彈出廣告信息框實例代碼:右下角彈出視窗效果是常見的彈出視窗效果之一,比如可以作為廣告視窗,也可以作為網站的一些公告或者通知,非常的實用,下麵就通過實例簡單介紹一下如何實現此功能,代碼如下:網頁右下角的信息框-螞蟻部落 3秒後會在右下角自動彈出視窗,如果沒有彈出請點擊這個按鈕 您有新的短.....
  • div垂直水平居中代碼實例:本章節分享一段代碼實例,它演示瞭如何讓div實現全屏垂直水平居中和指定元素的內容垂直水平居中。代碼實例如下:螞蟻部落 以上代碼實現了我們的要求,能夠實現居中效果,代碼比較簡單,就是基本的邏輯問題。原文地址是:http://www.softwhy.com/forum.ph....
  • jquery如何阻止子元素相應mouseout事件:mouseout有一個特點,當滑鼠移入子元素的時候,也會觸發此事件,但是在實際應用中這個特點往往不是我們想要的,下麵就通過代碼實例介紹一下如何實現此效果,代碼實例如下:螞蟻部落 以上代碼實現了我們的要求,當滑鼠指針移入子div的時候,不會觸發事件....
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...