当前位置: 移动技术网 > IT编程>开发语言>JavaScript > jquery动态加载select下拉框示例代码

jquery动态加载select下拉框示例代码

2019年03月19日  | 移动技术网IT编程  | 我要评论
代码如下: <head><title>jquery实现动态加载select下拉选项</title> <script type="text/

代码如下:


<head><title>jquery实现动态加载select下拉选项</title>
<script type="text/javascript">
function init(){
makemoduleselect();
}
//加载模板下拉框选项
function makemoduleselect(){
$.ajax({
url : 'indexstatisticsaction_getselect.',
data: { page:'clientindexstatistics.jsp',method:'get_modtitlecode'},
success : function(result){
$("#makemodule").append(result);
}
});
}</script>
</head>
<body onload="init()">
下拉框<select name="makemodule" id="makemodule" style='width:130px' onchange='makemoduleselected()'>
<option> ------- </option>
</select></body>


以上html被加载时,由于body标签里面设置了onload属性,则其对应的javascript函数会运行,最后到 function makemoduleselect(),再来看看这个函数:

url属性,类似于ajax的跳转url,这里我用了同一个路径下的jsp页面(indexstatisticsaction_getselect.jsp),下面会再展示;
data属性,将作为请求的参数,由request获取;
success属性,表示该jquery的ajax请求成功返回后将执行的代码,这里的$("#makemodule")指的是下拉框。

下面是ajax请求的url所对应的jsp,这里删掉了jdbc相关的包,自行引入嘛,jdbc的就不多说了,根据需要把业务逻辑码出来吧。

. 代码如下:


<%@ page import="java.util.*"%>
<%@ page import="java.sql.resultset"%>
<%@ page import="java.io.printwriter"%>
<%
string userid = (string) session.getattribute("userid");
string method = request.getparameter("method");
string frompage = request.getparameter("page");
string sql1 = "select modtitlename,modtitlecode from makemodule where userid = '?userid?' and modulename_en='?modulename_en?' group by modtitlename ";
system.out.println("---getting select_option from:"+frompage+"----" + new date());

//获取模板选项
if(method.equals("get_modtitlecode")){
string sql = sql1.replace("?userid?",userid);
if(frompage.equals("acindexstatistics.jsp")){
sql = sql.replace("?modulename_en?","acsta");
}else if(frompage.equals("apindexstatistics.jsp")){
sql = sql.replace("?modulename_en?","apsta");
}else if(frompage.equals("clientindexstatistics.jsp")){
sql = sql.replace("?modulename_en?","terminalsta");
}
system.out.println(sql);
stringbuffer rsoption = new stringbuffer();
db db = new db();
try {
db.preparequery();
resultset rs = db.executequery(sql);
while (rs!=null && rs.next()) {
rsoption.append("<option value='"+rs.getstring("modtitlecode")+"'>"+stringoperator.iso2gb(rs.getstring("modtitlename"))+"</option>");
}
rs.close();
} catch (exception e) {
e.printstacktrace();
} finally {
db.endquery();
}
printwriter pout = response.getwriter();
pout.write(rsoption.tostring());
pout.flush();
pout.close();
}
%>


上面的sql语句将取出两个值,分别为select下拉框的显示值和真值,套个<option>标签回发就可以了。

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

相关文章:

验证码:
移动技术网