jquery form表單獲取內(nèi)容以及綁定數(shù)據(jù)
在日常開(kāi)發(fā)的過(guò)程中,難免會(huì)用到form表單,我們需要獲取表單的數(shù)據(jù)保存到數(shù)據(jù)庫(kù),或者拿到后臺(tái)的一串json數(shù)據(jù),要將數(shù)據(jù)綁定到form表單上,這里我寫(xiě)了一個(gè)基于jquery的,formHelp插件,使用起來(lái)也很簡(jiǎn)單:
獲取表單的數(shù)據(jù):$("#formid").serializeJson();
綁定數(shù)據(jù)到表單:$("#formid").setForm(json);
jquery.formHelp.js插件
/** * 將form里面的內(nèi)容序列化成json * 相同的checkbox用分號(hào)拼接起來(lái) * @param {dom} 指定的選擇器 * @param {obj} 需要拼接在后面的json對(duì)象 * @method serializeJson * */ $.fn.serializeJson=function(otherString){ var serializeObj={}, array=this.serializeArray(); $(array).each(function(){ if(serializeObj[this.name]){ serializeObj[this.name]+=';'+this.value; }else{ serializeObj[this.name]=this.value; } }); if(otherString!=undefined){ var otherArray = otherString.split(';'); $(otherArray).each(function(){ var otherSplitArray = this.split(':'); serializeObj[otherSplitArray[0]]=otherSplitArray[1]; }); } return serializeObj; }; /** * 將josn對(duì)象賦值給form * @param {dom} 指定的選擇器 * @param {obj} 需要給form賦值的json對(duì)象 * @method serializeJson * */ $.fn.setForm = function(jsonValue){ var obj = this; $.each(jsonValue,function(name,ival){ var $oinput = obj.find("input[name="+name+"]"); if($oinput.attr("type")=="checkbox"){ if(ival !== null){ var checkboxObj = $("[name="+name+"]"); var checkArray = ival.split(";"); for(var i=0;i<checkboxObj.length;i++){ for(var j=0;j<checkArray.length;j++){ if(checkboxObj[i].value == checkArray[j]){ checkboxObj[i].click(); } } } } } else if($oinput.attr("type")=="radio"){ $oinput.each(function(){ var radioObj = $("[name="+name+"]"); for(var i=0;i<radioObj.length;i++){ if(radioObj[i].value == ival){ radioObj[i].click(); } } }); } else if($oinput.attr("type")=="textarea"){ obj.find("[name="+name+"]").html(ival); } else{ obj.find("[name="+name+"]").val(ival); } }) }
html測(cè)試代碼
<!DOCTYPE html> <html> <head lang="en"> <meta charset="UTF-8"> <title>jQueryFormHelp練習(xí)</title> <script src="http://libs.baidu.com/jquery/2.0.0/jquery.js"></script> <script src="jquery.formHelp.js"></script> <script type="text/javascript"> $(function () { $("#form").setForm({a: '張三家的附近可考慮將', b: '王五', c: '王五', d: 'nishi yaldjlkfjal ',e:7,f:'8;10',i:'王'}); }); function submitForm(){ console.log($("#form").serializeJson('id:12;name:13;')); } </script> </head> <body> <form id="form"> <div><input type="text" name="a" /></div> <div><input type="text" name="b" id="b" /></div> <div><input type="hidden" name="c" id="c" /></div> <div> <textarea name="d" rows="8" cols="40"></textarea> <input type="checkbox" name="f" value="10"/> </div> <div><select name="e"> <option value="5" selected="selected">5</option> <option value="6">6</option> <option value="7">7</option> </select></div> <div> <input type="checkbox" name="f" value="8" /> <input type="checkbox" name="f" value="9"/> </div> <div> <input name="i" type="radio" value="王" />王 <input name="i" type="radio" value="小" />小 </div> <div> <input type="button" name="g" value="Submit" id="g" onclick="submitForm()"/> </div> </form> </body> </html>
以上就是jquery獲取form表單內(nèi)容以及綁定數(shù)據(jù)到form表單的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助。
- jQuery獲取標(biāo)簽文本內(nèi)容和html內(nèi)容的方法
- JQuery獲取與設(shè)置HTML元素的內(nèi)容或文本的實(shí)現(xiàn)代碼
- jQuery 獲取、設(shè)置HTML或TEXT內(nèi)容的兩種方法
- jquery獲取table中的某行全部td的內(nèi)容方法
- jQuery獲取選中內(nèi)容及設(shè)置元素屬性的方法
- jQuery 同時(shí)獲取多個(gè)標(biāo)簽的指定內(nèi)容并儲(chǔ)存為數(shù)組
- JQuery 獲取多個(gè)select標(biāo)簽option的text內(nèi)容(實(shí)例)
- jQuery獲取table行數(shù)并輸出單元格內(nèi)容的實(shí)現(xiàn)方法
- 詳解jQuery獲取特殊屬性的值以及設(shè)置內(nèi)容
- JS和jQuery通過(guò)this獲取html標(biāo)簽中的屬性值(實(shí)例代碼)
- jquery獲取自定義屬性(attr和prop)實(shí)例介紹
- jQuery HTML獲取內(nèi)容和屬性操作實(shí)例分析
相關(guān)文章
javascript比較語(yǔ)義化版本號(hào)的實(shí)現(xiàn)代碼
這篇文章先是給大家簡(jiǎn)單的介紹了下語(yǔ)義化版本號(hào),而后再用實(shí)例代碼演示語(yǔ)義化版本號(hào)的比較方法,有需要的朋友們可以參考借鑒。2016-09-09js調(diào)用瀏覽器打印模塊實(shí)現(xiàn)點(diǎn)擊按鈕觸發(fā)自定義函數(shù)
把瀏覽器打印的功能保留并賦予到自己添加的按鈕當(dāng)中,可以在點(diǎn)擊按鈕的同時(shí)觸發(fā)自定義的函數(shù)2014-03-03一個(gè)關(guān)于javascript匿名函數(shù)的問(wèn)題分析
一個(gè)關(guān)于javascript匿名函數(shù)的問(wèn)題分析,學(xué)習(xí)js的朋友可以參考下2012-03-03return false,對(duì)阻止事件默認(rèn)動(dòng)作的一些測(cè)試代碼
很明顯我們每個(gè)函數(shù)都返回false,如果返回值可以阻止事件默認(rèn)動(dòng)作,那么文本框?qū)o(wú)法輸入任何內(nèi)容。 看下面我測(cè)試的結(jié)果,注意紅的部分。2010-11-11微信小程序?qū)崿F(xiàn)列表?xiàng)l件篩選
這篇文章主要為大家詳細(xì)介紹了微信小程序?qū)崿F(xiàn)列表?xiàng)l件篩選,篩選框的效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-07-07JavaScript中的ParseInt("08")和“09”返回0的原因分析及解決辦法
這篇文章主要介紹了JavaScript中ParseInt("08")和“09”返回0的原因分析及解決辦法的相關(guān)資料,需要的朋友可以參考下2016-05-05微信小程序?qū)崿F(xiàn)左側(cè)滑動(dòng)導(dǎo)航欄
這篇文章主要為大家詳細(xì)介紹了微信小程序?qū)崿F(xiàn)左側(cè)滑動(dòng)導(dǎo)航欄,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-10-10