今天继续写那个传数量的ajax
整体代码如下
//var a=document.getElementById('cj').value; var a=document.getElementById('cj').innerHTML; //alert(a); //JS layui.use(['element', 'layer', 'util'], function(){ var element = layui.element ,layer = layui.layer ,util = layui.util ,$ = layui.$; $.ajax({ url: "getnum?kind="+a, type: 'post', dataType: 'json',//ajax的dataType text 和json区别??????? success: function (res) { var dd=document.getElementById('cj'); dd.innerHTML=a+"("+res[0].value+")"; //alert("xing"); } }); });
List<Integer> num =newsdao.getnum(); System.out.println("为社么"); JSONArray json =new JSONArray(); for(int i=0;i<num.size();i++){ JSONObject ob=new JSONObject(); System.out.println(num.get(i)); ob.put("value", num.get(i)); // ob.put("wname", list.get(i).getBwname()); json.put(ob); } System.out.println(json.toString()); response.getWriter().write(json.toString());
最重要的是后面的后短代码,我获取所有种类新闻的数量,然后通过阿里的fastjson的jsonarray和jsonobject拼接成我自己需要的json格式,这是最关键的,我之前的ajax都是依据近似现成的代码来实现功能,没有特别想过自己去试想一个ajax的返回值。主要是jsonarray,jsonobject还有map的交织配合。
注意ajax的数据格式,这里返回的是json就要写json,如果返回的是字符串,数据类型就是text。