文章詳情頁
ajax異步讀取后臺傳遞回的下拉選項(xiàng)的值方法
瀏覽:202日期:2022-06-11 11:58:01
jsp中html相關(guān)代碼
<tr>
<td>請選擇展會:</td>
<td colspan="3">
<select name="select" id="jieci" onchange="getChange()">
<option value="">選擇展會</option>
</select>
<script Language="JavaScript">
loadjieci("- 選擇展會 -");
</script>
<span> *</span>
<span id="mesjieci"></span>
</td>
</tr>
js中相關(guān)代碼
<script Language="JavaScript">
function loadjieci(str) {
/** 異步加載屆次 */
$.getJSON("/DictsAction.do?actionType=jieci",
function (responseData, status) {
if (status != "") {
$("#jieci").empty();
$("<option/>").html("- 選擇展會 -").val("- 選擇展會 -").appendTo("#jieci");
$(responseData).each(function (n) {
$("<option/>").html(this.name).val(this.code).appendTo("#jieci");
});
//默認(rèn)顯示請選擇
$("#jieci").val(str);
} else {
alert("屆次加載失敗!");
}
});
}
</script>
struts-config.xml中相關(guān)配置
<!-- ajax異步加載字典 --> <action path="/DictsAction" type="oa.sys016.oagzxxgl.action.DictsAction" scope="request" />
java后臺代碼
package oa.sys016.oagzxxgl.action;
import java.io.PrintWriter;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import net.sf.json.JSONArray;
import org.apache.struts.action.Action;
import org.apache.struts.action.ActionForm;
import org.apache.struts.action.ActionForward;
import org.apache.struts.action.ActionMapping;
import cn.com.chx.bo.AppBo;
/**
* 通過ajax加載屆次選擇下拉列表的選擇項(xiàng)
* @author liu
*
*/
public class DictsAction extends Action{
private AppBo appBo = null;
@Override
public ActionForward execute(ActionMapping mapping, ActionForm form,
HttpServletRequest request, HttpServletResponse response)
throws Exception {
// 設(shè)置編碼
response.setContentType("application/json;charset=UTF-8");
response.setCharacterEncoding("UTF-8");
PrintWriter out = response.getWriter();
appBo = new AppBo();
try {
// 獲取ActionType
String actionType = request.getParameter("actionType");
if (actionType != null && actionType.equals("jieci")) { // 查詢屆次
String jieciJson = getJieciJson();
out.print(jieciJson);
}
} catch (Exception e) {
e.printStackTrace();
} finally {
out.close();
}
return null;
}
private String getJieciJson() {
// 查詢屆次
List jieciList;
try {
jieciList = appBo.query("SELECT ID AS CODE,ZH_NAME AS NAME FROM ZH_GZ_INFOX");
List<Map<String, String>> lists = new ArrayList<Map<String, String>>();
if (jieciList.size() > 0) {
for (int i = 0; i < jieciList.size(); i++) {
Map<String, String> maps = new HashMap<String, String>();
maps.put("code",
(String) ((HashMap) jieciList.get(i)).get("CODE"));
maps.put("name",
(String) ((HashMap) jieciList.get(i)).get("NAME"));
lists.add(maps);
}
}
// [{"id":"1","name":"CIMT2015"},{"id":"2","name":"CCMT2016"}]
JSONArray json = JSONArray.fromObject(lists);
return json.toString();
} catch (Exception e) {
e.printStackTrace();
}
return null;
}
}
以上這篇ajax異步讀取后臺傳遞回的下拉選項(xiàng)的值方法就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持。
標(biāo)簽:
Ajax
相關(guān)文章:
1. AJAX檢測用戶名是否存在的方法2. PHP下ajax跨域的解決方案之jsonp實(shí)例分析3. Spring MVC+ajax進(jìn)行信息驗(yàn)證的方法4. 利用ajax+php實(shí)現(xiàn)商品價格計(jì)算5. 爬取今日頭條Ajax請求6. 詳談ajax返回?cái)?shù)據(jù)成功 卻進(jìn)入error的方法7. 通過Ajax請求動態(tài)填充頁面數(shù)據(jù)的實(shí)例8. ASP.NET MVC使用JSAjaxFileUploader插件實(shí)現(xiàn)單文件上傳9. Ajax實(shí)現(xiàn)省市縣三級聯(lián)動10. 利用promise及參數(shù)解構(gòu)封裝ajax請求的方法
排行榜

網(wǎng)公網(wǎng)安備