Jquery判斷form表單數(shù)據(jù)是否變化
來源:易賢網 閱讀:2309 次 日期:2016-07-14 16:42:04
溫馨提示:易賢網小編為您整理了“Jquery判斷form表單數(shù)據(jù)是否變化”,方便廣大網友查閱!

本文實例為大家分享了Jquery判斷form表單數(shù)據(jù)是否變化的三大步驟,供大家參考,具體內容如下

1、思路為:修改時點擊一行datagrid,并進行頁面跳轉數(shù)據(jù)綁定,在提交form時,序列號form表單,并重新獲取datagrid選中的行數(shù)據(jù),進行數(shù)據(jù)比較。</span>  

/** 

 * 判斷form內屬性值是否被修改 

 * 

 * @param jsonForm 對應修改的form序列化后的json數(shù)據(jù) 

 * @param row 對應datagrid選中的數(shù)據(jù)源 

 * 

 * @Return true 存在修改項 

 *     false 不存在修改項 

 */

isModified:function(jsonForm,row){ 

  for(key in jsonForm){ 

    //form中存在,但數(shù)據(jù)源datagrid中不存在 

    if(row[key] == undefined){ 

      continue; 

    } 

    //form中""或null,但數(shù)據(jù)源datagrid中為null或""時,不進行比較 

    if(!((jsonForm[key] == null || jsonForm[key] == '') && (row[key] == null || row[key] == ''))){ 

      //如果值不同,則返回true 

      if(jsonForm[key] != row[key]) 

        return true; 

    } 

  } 

  return false; 

}

2、獲取變化的值前后變化信息,由于項目需要記錄值變更記錄,并保存column中英文信息,如下:

/** 

   * 獲取form被修改信息 

   * 

   * @param jsonForm 對應修改的form序列化后的json數(shù)據(jù) 

   * @param row 對應datagrid選中的數(shù)據(jù)源 

   * @param columnJSModel 為表單form中name屬性中英對照js,需在update.jsp中引用此js文件 

   * 

   * @Return json 數(shù)據(jù)如:[{"updateColumn":"loanRatio","updateColName":"額比例","updateContent":"由11變更為100.00"}, 

   *     {"updateColumn":"loanQuotaTypeName","updateColName":"比例形式","updateContent":"由 卡 變更為 實物"}] 

   * 

   */

  getModifiedField:function(jsonForm,row,columnJSModel){ 

    var modifiedArry = []; 

    var jsonArrStr = ''; 

    for(key in jsonForm){ 

      //form中存在,但數(shù)據(jù)源datagrid中不存在 

      if(row[key] == undefined){ 

        continue; 

      } 

      //form中""或null,但數(shù)據(jù)源datagrid中為null或""時,不進行比較 

      if(!((jsonForm[key] == null || jsonForm[key] == '') && (row[key] == null || row[key] == ''))){ 

        //如果值不同,則返回true 

        if(jsonForm[key] != row[key]){ 

          var jsonObj = {}; 

          jsonObj.updateColumn = key; 

          jsonObj.updateColName = columnJSModel[key]; 

          jsonObj.updateContent = '由'+ row[key] + '變更為' + jsonForm[key]; 

          modifiedArry[modifiedArry.length] = jsonObj; 

        } 

      } 

    } 

    jsonArrStr = JSON.stringify(modifiedArry); 

    //console.log(jsonArrStr); 

    return jsonArrStr; 

  }

3、其中的columnJSModel為中英對照JS實體,ratio、qutaTypeName分別對應form中的name屬性名,如下:

var policyColumn = { 

    ratio : '比例', 

    quotaTypeName : '比例形式'

};

以上就是本文的全部內容,希望對大家的學習有所幫助。

更多信息請查看網絡編程

2025國考·省考課程試聽報名

  • 報班類型
  • 姓名
  • 手機號
  • 驗證碼
關于我們 | 聯(lián)系我們 | 人才招聘 | 網站聲明 | 網站幫助 | 非正式的簡要咨詢 | 簡要咨詢須知 | 新媒體/短視頻平臺 | 手機站點 | 投訴建議
工業(yè)和信息化部備案號:滇ICP備2023014141號-1 云南省教育廳備案號:云教ICP備0901021 滇公網安備53010202001879號 人力資源服務許可證:(云)人服證字(2023)第0102001523號
聯(lián)系電話:0871-65099533/13759567129 獲取招聘考試信息及咨詢關注公眾號:hfpxwx
咨詢QQ:1093837350(9:00—18:00)版權所有:易賢網