欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

基于JavaScript將表單序列化類型的數(shù)據(jù)轉(zhuǎn)化成對象的處理(允許對象中包含對象)

 更新時(shí)間:2015年12月28日 09:45:12   作者:chua1989  
這篇文章主要介紹了基于JavaScript將表單序列化類型的數(shù)據(jù)轉(zhuǎn)化成對象的處理(允許對象中包含對象) 的相關(guān)資料,需要的朋友可以參考下

表單序列化類型的數(shù)據(jù)是指url傳遞的數(shù)據(jù)的格式,形如"key=value&key=value&key=value"這樣的key/value的鍵值對。一般來說使用jQuery的$.fn.serialize函數(shù)能達(dá)到這樣的效果。如何將這樣的格式轉(zhuǎn)化為對象?

  我們知道使用jQuery的$.fn.serializeArray函數(shù)得到的是一個(gè)如下結(jié)構(gòu)的對象

[
  {
    name: "startTime"
    value: "2015-12-02 00:00:00"
  },
  {
    name: "endTime"
    value: "2015-12-25 23:59:59"
  }
]

  這是一個(gè)對象數(shù)組,但有時(shí)候我們希望得到的是如下結(jié)構(gòu)的對象

{
  "startTime": "2015-12-02 00:00:00"
  "endTime": "2015-12-25 23:59:59"
}

  所以這里需要一個(gè)轉(zhuǎn)化函數(shù)。

處理步驟如下:

  1.使用"&"分隔將每一個(gè)鍵值對分開然后循環(huán)處理每一個(gè)鍵值對

  var properties = serializedParams.split("&");
  for (var i = 0; i < properties.length; i++) {
    //處理每一個(gè)鍵值對
    evalThem(properties[i]);
  }; 

  2.從"="符號切分指定的鍵值對,并對每個(gè)鍵和值使用decodeURIComponent解析uri 組件編碼(因?yàn)閡rl傳遞的序列化數(shù)據(jù)一般都是經(jīng)過uri組件編碼的)

    var strAry = new Array();
    strAry = str.split("=");
    //使用decodeURIComponent解析uri 組件編碼
    for(var i = 0; i < strAry.length; i++){
      strAry[i] = decodeURIComponent(strAry[i]);
    }
    var attributeName = strAry[0];
    var attributeValue = strAry[1].trim(); 

  3.如果值包含"="符號,需要額外處理(值合并)。       

 if(strAry.length > 2){
      for(var i = 2;i<strAry.length;i++){
        attributeValue += "="+strAry[i].trim();
      }
    } 

  這里面有一個(gè)處理,就是值沒有的時(shí)候就不會(huì)往最終對象里面添加。這個(gè)可以根據(jù)自己的情況選擇刪除這段代碼與否

   if(!attributeValue){
      return ;
    } 

  4.如果鍵是“obj.obj.obj”這種由"."符號鏈接的,需要將它作為對象包含對象來處理。處理的方法是將鍵通過"."分解,然后去查看臨時(shí)對象obj中是否已經(jīng)包含分解出來的對象,如果是則將數(shù)據(jù)附加到已有的對象上。源碼如下  

 var attriNames = attributeName.split("."),
      curObj = obj;
    for(var i = 0; i < (attriNames.length - 1); i++){
      curObj[attriNames[i]]?"":(curObj[attriNames[i]] = {});
      curObj = curObj[attriNames[i]];
    }
    curObj[attriNames[i]] = attributeValue.trim(); 

  這里面我們看到網(wǎng)上有對賦值部分是這么處理的

eval("obj."+attributeName+"=\""+attributeValue.trim()+"\";"); 

  這個(gè)很有問題,一個(gè)是不能正確處理4中對象包含對象的問題(尤其是有兩個(gè)元素?fù)碛型粋€(gè)父對象的時(shí)候,比如"test.id=1&test.name='chua'"都擁有父對象test)。另外一個(gè)就是值attributeValue中包含單引號、雙引號時(shí)無法正確處理。所以使用賦值"="最保險(xiǎn)。

  所以最終完整的源碼如下

/*
serializedParams格式為"key1=value1&key2=value2". 
也支持'key.sonkey=value' 
 */
function paramString2obj (serializedParams) {  
  var obj={};
  function evalThem (str) {
    var strAry = new Array();
    strAry = str.split("=");
    //使用decodeURIComponent解析uri 組件編碼
    for(var i = 0; i < strAry.length; i++){
      strAry[i] = decodeURIComponent(strAry[i]);
    }
    var attributeName = strAry[0];
    var attributeValue = strAry[1].trim();
    //如果值中包含"="符號,需要合并值
    if(strAry.length > 2){
      for(var i = 2;i<strAry.length;i++){
        attributeValue += "="+strAry[i].trim();
      }
    }
    if(!attributeValue){
      return ;
    }
    var attriNames = attributeName.split("."),
      curObj = obj;
    for(var i = 0; i < (attriNames.length - 1); i++){
      curObj[attriNames[i]]?"":(curObj[attriNames[i]] = {});
      curObj = curObj[attriNames[i]];
    }
    //使用賦值方式obj[attributeName] = attributeValue.trim();替換
    //eval("obj."+attributeName+"=\""+attributeValue.trim()+"\";");
    //解決值attributeValue中包含單引號、雙引號時(shí)無法處理的問題
    curObj[attriNames[i]] = attributeValue.trim();
  };
  var properties = serializedParams.split("&");
  for (var i = 0; i < properties.length; i++) {
    //處理每一個(gè)鍵值對
    evalThem(properties[i]);
  };
  return obj;
}

以上內(nèi)容是基于JavaScript將表單序列化類型的數(shù)據(jù)轉(zhuǎn)化成對象的處理(允許對象中包含對象),希望本文分享能夠給大家?guī)韼椭?/p>

相關(guān)文章

最新評論