首頁 > web前端 > js教程 > js實作前後台傳送Json程式碼實例

js實作前後台傳送Json程式碼實例

小云云
發布: 2018-03-30 09:28:30
原創
1855 人瀏覽過

無論使用什麼框架都存在著從controller向Html頁面或jsp頁面傳遞資料的問題,最常用的方式是傳遞Json字串。以前對這塊知識有些模糊,現在整理一下,希望能幫助大家。

【Jquery基本方法】

實作傳值常用的是Jquery以及內部封裝的ajax。首先來看看jquery的get()和post()語法。 get()方法是從伺服器取得數據,其主要參數就是取得後台請求位址,以及負責處理的回呼函數:

$.get(URL,callback);

$("button").click(function(){ 
 $.get("demo_test.php",function(data,status){ 
  alert("数据: " + data + "\n状态: " + status); 
 }); 
});
登入後複製

post透過HTTP post方法請求資料:

$.post(URL,data,callback);

$("button").click(function(){ 
  $.post("/try/ajax/demo_test_post.php", 
  { 
    name:"菜鸟教程", 
    url:"http://www.runoob.com" 
  }, 
    function(data,status){ 
    alert("数据: \n" + data + "\n状态: " + status); 
  }); 
});
登入後複製

【spring mvc框架+Jquery ajax】

spring mvc框架的controller通過標註方法向js傳回Map類型參數。

@RequestMapping("update") 
@ResponseBody //此批注是ajax获取返回值使用 
public Map<String,Object> update(Long num,BigDecimal amount){ 
  map<string,Object> resultMap=new HashMap<string,Object>(); 
   
  if(num==null || agentId==null || amount==null){ 
    resultMap.put("result","参数不合法"); 
    return resultMap; 
  } 
  resultMap.put("result",result); 
   
}
登入後複製

jquery ajax獲得回傳值:

var params={}; 
params.num=num; 
params.id=id; 
params.amount=amount; 
$.ajax({ 
  async:false, 
  type:"post", 
  url:"uset/update", 
  data:params, 
  dataType:"json", 
  success:function(data){ 
    if(data.result==&#39;success&#39;){ 
      alert(&#39;修改成功&#39;); 
    }else{ 
      alert(&#39;修改失败&#39;); 
    } 
  }, 
  error:function(data){ 
    alert(data.result); 
  } 
   
})
登入後複製

如果在js中定義的參數與持久層定義的javabean保持一致,controller層同樣可以接收實體。

【MUI綁定資料實例】

使用jquery很容易取得controller所獲得的json值,那我們要如何操作json值,讓其綁定到頁面控制項呢?首先我們簡單理解json的結構:

var employees=[{"name":"Jon","age":12},{"name":"Tom","age":14}];
登入後複製

如上面定義的Json對象,{}表示對象,[]表示數組,"" 表示屬性或值,: 表示後者是前者的值。

取得json物件中的值:var name=employees[0].name;

修改:employees[0].name="LiMing";

#MUI框架中的應用舉例,實作list中加入li 標籤:

mui.init();
var url="queryUser"
mui.ajax(url,{
	data:{
		&#39;type&#39;:1,
		&#39;limit&#39;:10
	},
	dataType:&#39;json&#39;,
	type:&#39;post&#39;,
	success:function(data){
		var songs=data.result.songs;
		var list=document.getElementById("list");
		var fragment=document.creeateDocumentFramgment();
		
		var li;
		mui.each(songs,function(index,item){
			var id=item.id,
			name=item.album.name,
			author=item.artists[0].name;
			
			li=document.createElement(&#39;li&#39;);
			li.className="mui-table-view-cell mui-media";
			li.innerHTML=&#39;<a class="mui-navigate-right" id=&#39;+ id +&#39; data-audio=&#39;+ audio +&#39;>&#39;+&#39;<img class="mui-media-object mui-pull-left" srcload="&#39;+picUrl+&#39;">&#39;+&#39;<p class="mui-media-body">&#39;+name+&#39;<p class="mui-ellipsis">&#39;+author+&#39;</p>&#39;+&#39;</p>&#39;+&#39;</a>&#39;;
		fragment.appendChild(li);
		})
		
		list.appendChild(fragment);
		mui(document).imageLazyload({
			placeholder:&#39;../img/60*60.gif&#39;;
		});
		
	},erro:function(xhr,type,errorThrown){
		console.log(type);
	}
	
});
//列表点击事件
mui("#list").on(&#39;tap&#39;,&#39;li a&#39;,function(){
	var id=this.getAttribute(&#39;id&#39;);
	var audio=this.getAttribute(&#39;data-audio&#39;);
	mui.openWindow({
		url:&#39;music.html&#39;,
		id:&#39;music.html&#39;,
		extras:{
			musicId:id,
			audioUrl:audio
		}
	});
});
登入後複製

【總結】

#json格式的資料相對於xml檔案來說,傳輸速度快且穩定,在前端設計中是個非常好的選擇。

相關推薦:

怎麼透過ajax傳送json陣列到php,並透過php將資料插入資料庫

以上是js實作前後台傳送Json程式碼實例的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板