在jsp中下拉框中如何获取数据库中的值

在jsp中下拉框中如何获取数据库中的值,第1张

但是还有一种方法通过js获取下拉框的值<select name="sel" onchange="check()">-- 增加onchange事件<%while (rs.next()) {%><option value="">-- 这里没有给选项赋值-- 改为,如:<option value="<%=rs.getString(1)%>"><%=rs.getString(1)%></option><%}%></select><script type="text/javascript">function check(){var id = document.getElementsByName("sel").value-- 获取下拉框的值如:拼接url打开页面,var url = 'xxxx.do?id=' + id//注,具体的url你要自己拼写,我这个是列子,不能用的方法1,在本窗口打开页面:window.location = url 方法2,新窗口打开页面window.open(url)}</script>追问: 我终于发现了,能读取数据,可是把读取的数据放入数据库中就有问题了,难道还要转码才行吗? 回答: 当然`~~ 追问: 页面编码是gb2312那我要怎样转码呢? 回答: 首先你要知道你的数据库的是什么编码的,你页面的编码要符合你数据库的编码,这样的转码才是正确的 追问: 现在我不是从页面读取数据了,而是直接在程序中测试Date.valueOf("1987-3-7")比如我用这样的方法把这个数据放到数据库中去就自动变成了1905-6-1了,感觉太怪了这个就和编码无关了 回答: 你具体的代码我也不知道,也不好给你说,给你个UTF-8转GB2312的代码吧private String utf8Togb2312(String str){StringBuffer sb = new StringBuffer()for(int i=0i<str.length()i++) {char c = str.charAt(i)switch (c) {case '+':sb.append(' ')breakcase '%':try {sb.append((char)Integer.parseInt(str.substring(i+1,i+3),16))}catch (NumberFormatException e) {throw new IllegalArgumentException()}i += 2breakdefault:sb.append(c)break}}String result = sb.toString()String res=nulltry{byte[] inputBytes = result.getBytes("8859_1")

首先你得从后台获取德奥数据库的内容,然后转发到jsp页面,通过jstl或者el来读取后台传入过来的内容。

后台可以把数据库查询到的数据放在一个数组或者是集合中,然后使用request.getRequestDispatcher.forward()把数据或者集合传到前台的下拉菜单的页面中,再在前台下拉菜单页面中使用<select><c:foreach><option value='xxx'>来遍历后台传出来的数据或者集合的内容

后台很容易实现,至于前台页面如果你不会jstl和el 的话可以上网看下对应用法,基本认真看的话2个小时就可以掌握基础了


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/10826909.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-11
下一篇 2023-05-11

发表评论

登录后才能评论

评论列表(0条)

保存