jsp从数据库获取数据填充下拉框实现二级联动菜单的方法

栏目: JSP · 发布时间: 7年前

内容简介:jsp从数据库获取数据填充下拉框实现二级联动菜单的方法

本文实例讲述了jsp从数据库获取数据填充下拉框实现二级联动菜单的方法。分享给大家供大家参考,具体如下:

项目告一段落,现在将遇到的比较实用的东西记录下来,写了多遍了,谨记于此,以备查看!

1、首先在数据库中获取第一个下拉框的数据:

<s:select listKey="tsFrom" id="t_tsfrom" cssClass="required" 
listValue="tsFrom" cssStyle="width:90" list="tsfrom1" 
name="tsFrom" theme="simple" headerKey="" 
onchange="getTsFromDescribe(this);" headerValue="--请选择--" />

后台处理:

@Autowired 
private CustomMaManager custommamanager;//注解相当的好用啊,代码都省了一大截 
tsfrom1 = custommamanager.getTsFrom();

Service:

//得到投诉来源 
public List<CustomManage> getTsFrom(){ 
  return custommanagedao.getTsFrom(); 
}

dao:

/**得到产品类型**/ 
public List<CustomManage> getTsFrom(){ 
  return this.find("SELECT distinct new CustomManage(tsFrom,'2') FROM CustomManage C WHERE C.tsFrom IS NOT NULL ORDER BY tsFrom ASC");
}

注意:Oracle在 java 代码里取出重复值与SqlServer不一样,它得使用:

SELECT distinct new CustomManage(tsFrom,'2') FROM CustomManage C WHERE C.tsFrom IS NOT NULL ORDER BY tsFrom ASC

先new实体bean(CustomManage) 然后在实体bean中给相应字段设置构造方法,不然将会出现后台已经返回了值,但是在前台下拉框中不显示,下拉框空白的现象。

public CustomManage(String khname,int s){ 
  this.khname=khname; 
} 
public CustomManage(String cpname,String type){ 
  if("1".equals(type)){ 
   this.cpname=cpname; 
  }else if("2".equals(type)){ 
   this.tsFrom=cpname; 
  }else if("3".equals(type)){ 
   this.khname=cpname; 
  } 
}

这里需要在bean的实体类里面加入相应的构造方法,以此来供去重使用。

至此第一级的数据准备已经差不多了。使用S标签的list集合来获取后台传递过来的值。

2、第二级下拉菜单的级联====利用Ajax来获取数据

在第一级列表的onchange事件中编写:

//投诉信息来源信息级联 
function getTsFromDescribe(ts_describe){ 
 var tsfrom = $("#t_tsfrom").val(); 
 var tstsFrom = $("#ts_tsFrom").val(); 
 Ext.Ajax.request( { 
  url : '${ctx}/complaints/complaints!getTsFrom.action', 
  params : { 
   tsfrom : tsfrom//通过json形式将前台每次获取到的值传递给后台 
  }, 
  success : function(response) { 
   var json = Ext.util.JSON.decode(response.responseText); 
   if (json.success) { 
    var data = json.<strong>cmList</strong>; 
    if ("" == data) { 
     alert("请选择投诉类型"); 
     inputForm.t_tsfrom.focus(); 
     $("#ts_tsFrom").empty();//每次需要将上一次的数据进行清空 
    } else { 
     $("#ts_tsFrom").empty(); 
     //对获取到的数据进行迭代 
    for ( var i = 0; i < data.length; i++) { 
     var id = data[i]; 
     var name = data[i]; 
     $("#ts_tsFrom").append( 
       "<option value='" + id + "'>" + name + "</option>"); 
    } 
    dwr.util.removeAllOptions('tstsFrom'); 
    dwr.util.addOptions('tstsFrom', data); 
 } 
} 
} 
}); 
}

后台返回数据:

public void getTsFrom() throws Exception { 
  HttpServletResponse response = ServletActionContext.getResponse(); 
  String ts_names = tsfrom; 
  List<CustomManage> list = complaintsmanager.getTsDescribe(ts_names); 
  response.setContentType("text/javascript"); // 后台控制的代码 
  PrintWriter writer = response.getWriter(); 
  // 将得到的list集合转为JSON对象传给前台处理 
  JSONArray j = JSONArray.fromObject(list); 
  writer.println("{'success':true,'<strong>cmList</strong>':" + j.toString() + "}"); 
}

到此一个从数据库里动态获取值,并且实现二级菜单级联的功能就做的差不多了。发表出来希望对你对我都有好处哈。

这里加注一点就是在修改的时候下拉框的值不会保存,就是上一次点击提交的时候保存在数据库里的值无法填充到下拉框。

处理办法:

var op1 = document.getElementById("op1").value; 
if(op1!=null){ 
  $("#cp_validity").val(op1); //将取出来的值塞到下拉框中。一个萝卜一个坑 
} 
<input type="hidden" id="op1" value="${compDisposal.validity}">//使用表达式将存在数据库里的值取出来,放在隐藏域里面

希望本文所述对大家jsp程序设计有所帮助。


以上所述就是小编给大家介绍的《jsp从数据库获取数据填充下拉框实现二级联动菜单的方法》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

Programming in Haskell

Programming in Haskell

Graham Hutton / Cambridge University Press / 2007-1-18 / GBP 34.99

Haskell is one of the leading languages for teaching functional programming, enabling students to write simpler and cleaner code, and to learn how to structure and reason about programs. This introduc......一起来看看 《Programming in Haskell》 这本书的介绍吧!

Base64 编码/解码
Base64 编码/解码

Base64 编码/解码

XML 在线格式化
XML 在线格式化

在线 XML 格式化压缩工具

正则表达式在线测试
正则表达式在线测试

正则表达式在线测试