当前位置: 移动技术网 > IT编程>开发语言>JavaScript > 用户管理的设计_jquery的ajax实现二级联动效果

用户管理的设计_jquery的ajax实现二级联动效果

2017年12月12日  | 移动技术网IT编程  | 我要评论
页面效果 实现步骤 1.引入struts整合json的插件包 2.页面使用jquery的ajax调用二级联动的js //ajax的二级联动,使用选择的所

页面效果

实现步骤

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";
  }

其中,findsystemddllistbykeyword(jctid)是在数据字典service中实现的方法,主要根据数据类型名称查询数据字典,返回list集合对象

valueutils是一个工具类,pushvaluestack方法将list压入到struts2值栈的栈顶

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实现二级联动效果就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持移动技术网。

如您对本文有疑问或者有任何想说的,请点击进行留言回复,万千网友为您解惑!

相关文章:

验证码:
移动技术网