首頁 >web前端 >js教程 >用戶管理--用jquery的ajax實現二級連動

用戶管理--用jquery的ajax實現二級連動

巴扎黑
巴扎黑原創
2017-07-20 13:27:301350瀏覽

頁面效果


實作步驟

#1.引入struts整合json的外掛程式包

2.頁面使用jquery的ajax呼叫二級連動的js

//ajax的二级联动,使用选择的所属单位,查询该所属单位下对应的单位名称列表function findJctUnit(o){//货物所属单位的文本内容var jct = $(o).find("option:selected").text();$.post("elecUserAction_findJctUnit.do",{"jctID":jct},function(data,textStatus){               //先删除单位名称的下拉菜单,但是请选择要留下   $("#jctUnitID option").remove();if(data!=null && data.length>0){for(var i=0;i<data.length;i++){                          var ddlCode = data[i].ddlCode;                          var ddlName = data[i].ddlName;                          //添加到单位名称的下拉菜单中  var $option = $("<option></option>");
                          $option.attr("value",ddlCode);
                          $option.text(ddlName);
                          $("#jctUnitID").append($option);
                   }
            }
        });
        
    }

3.在Action類別中定義findJctUnit()方法,這裡要將傳回的List集合放置到堆疊頂,struts2將其轉換成json資料

/**  
    * @Name: findJctUnit
    * @Description: 使用jquery的ajax完成二级联动,使用所属单位,关联单位名称
    * @Parameters: 无
    * @Return: 使用struts2的json插件包*/public String findJctUnit(){//1:获取所属单位下的数据项的值(从页面提交的jctID值,不是数据字典中的ddlcode)String jctID = elecUser.getJctID();//2:使用该值作为数据类型,查询对应数据字典的值,返回List<ElecSystemDDL>List<ElecSystemDDL> list = elecSystemDDLService.findSystemDDLListByKeyword(jctID);//3:将List<ElecSystemDDL>转换成json的数组,将List集合放置到栈顶        ValueUtils.pushValueStack(list);return "findJctUnit";
    }
<span style="font-size: 14px">  其中,findSystemDDLListByKeyword(jctID)是在数据字典service中实现的方法,主要根据数据类型名称查询数据字典,返回list集合对象<br><br>  ValueUtils是一个工具类,pushValueStack方法将list压入到struts2值栈的栈顶</span>
public class ValueUtils {public static void pushValueStack(Object object) {
        ServletActionContext.getContext().getValueStack().push(object);
    }
}

  struts2的插件包會將壓入到struts2值堆疊的list集合中物件所有的屬性全部被json化

4.在struts.xml中定義

(1)修改 extends值

修改前

<!-- 系统管理 --><package name="system" extends="struts-default" namespace="/system">

#修改後

<!-- 系统管理 --><package name="system" extends="json-default" namespace="/system">
######(2)新增映射######
<!-- 如果是List集合,转换成json数组;如果是object对象,转换成json对象 --><result name="findJctUnit" type="json"></result>
#########完成上述步驟以後,即可實現選取所屬單位下拉框的值,在單位名稱下拉選項中有對應值。 ############在瀏覽器頁面查看json資料如下:######################若想針對某個屬性被json化,此時可以修改struts.xml檔###:######
<!-- 如果是List集合,转换成json数组;如果是object对象,转换成json对象 --><result name="findJctUnit" type="json"><param name="includeProperties">\[\d+\]\.ddlCode,\[\d+\]\.ddlName</param></result>
#########這裡使用正規表示式攔截一個或多個ddlCode和ddlName,這樣json資料只含有ddlCode和ddlName了。 ######

以上是用戶管理--用jquery的ajax實現二級連動的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn