谁知道怎么用ajax实现选择下拉框的时候动态从数据库读取数据吗

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了谁知道怎么用ajax实现选择下拉框的时候动态从数据库读取数据吗相关的知识,希望对你有一定的参考价值。

谁有这样的例子,麻烦给一个

我想实现这样的效果:上面有个下拉框,用户选择其中一个选项的时候,下面的表格会自动改动内容。

表格的内容是根据s_id的不同而变化,所以我需要在用户选择下拉列框后让s_id自动改变值,
并让表格自动根据s_id从数据库取数据。

加载这个表格是根据选择的s_id , 然后根据这个s_id从数据库取数据读进表格里。

怎么改动我的代码呢?我目前的代码实现不了

每次选择下拉框的时候去服务器查找数据.然后返回相应的内容.

参考技术A 先做一个JSP页面,就和你正常情况下根据ID查数据一样,得到ID,根据ID查询出数据。
循环出表格在页面上。
只是这个页面不会通过浏览器直接访问。
而是用ajax的异步去请求这个页面。

在你的当前操作页面上,定义一个div。
在取得responseText后,将responseText的值innerhtml给div。

当触发下拉的onchange事件,就发送一个异步请求,将ID传到服务端。

这样就可以动态改变了,不会刷新页面。

做起来挺简单的,只是我现在没有现成的代码。本回答被提问者采纳
参考技术B 楼上的回答和我想的查不多,我也需要这样的例子指导一下,希望知道的人能提供一个实例

ajax_get/post_两级联动

使用ajax实现菜单联动

通常情况下,GET请求用于从服务器上获取数据,POST请求用于向服务器发送数据。

 

需求:选择第一个下拉框的值,根据第一个下拉框的值显示第二个下拉框的值

 

  1. 首先使用GET方式。

 

客户端HTML页面显示第一个下拉选择框,给当前下拉选择框选择某个选项后,通过XMLHttpRequest向服务器发送请求,请求动态显示第二个下拉选择框。下面是对应的HTML页面的代码。

程序清单:Ajax02request/get/first.html

<!DOCTYPE html>

<html>

<head>

<meta name="author" content="silvan" />

<meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />

<title>发送GET请求</title>

<!-- select标签添加样式 -->

<style type="text/css">

select {

width: 160px;

font-size: 11pt;

}

</style>

</head>

<body>

<select name="first" id="first" onchange="change(this.value);">

<option value="0">---请选择---</option>

<option value="1" >中国</option>

<option value="2">美国</option>

<option value="3">日本</option>

</select>

<select name="second" id="second"></select>

<script type="text/javascript">

// 定义了XMLHttpRequest对象

var xmlrequest;

// 完成XMLHttpRequest对象的初始化

function createXMLHttpRequest(){

if(window.XMLHttpRequest){

// DOM 2浏览器

xmlrequest = new XMLHttpRequest();

}else if (window.ActiveXObject){

// IE浏览器

try{

xmlrequest = new ActiveXObject("Msxml2.XMLHTTP");

}catch (e){

try{

xmlrequest = new ActiveXObject("Microsoft.XMLHTTP");

}catch (e){

}

}

}

}

// 事件处理函数,当下拉列表选择改变时,触发该事件

function change(id){

// 初始化XMLHttpRequest对象

createXMLHttpRequest();

// 设置请求响应的URL

var uri = "second.jsp?id=" + id;

// 设置处理响应的回调函数

xmlrequest.onreadystatechange = processResponse;

// 打开与服务器响应地址的连接

xmlrequest.open("GET", uri, true);

// 发送请求

xmlrequest.send(null);

}

// 定义处理响应的回调函数

function processResponse(){

//响应完成且响应正常

if (xmlrequest.readyState == 4){

if (xmlrequest.status == 200){

// 将服务器响应以$符号分隔成字符串数组

var cityList = xmlrequest.responseText.split("$");

// 获取用于显示菜单的下拉列表

var displaySelect = document.getElementById("second");

// 将目标下拉列表清空

displaySelect.innerHTML = null;

// 以字符串数组的每个元素创建option

// 并将这些选项添加到下拉列表中

for (var i = 0 ; i < cityList.length ; i++){

// 创建一个<option.../>元素

var op = document.createElement("option");

op.innerHTML = cityList[i];

// 将新的选项添加到列表框的最后

displaySelect.appendChild(op);

}

}else{

//页面不正常

window.alert("您所请求的页面有异常。");

}

}

}

// 指定页面加载完成后指定change(id)函数

document.body.onload = change(document.getElementById("first").value);

</script>

</body>

</html>

 

采用GET请求将父菜单的ID作为参数发送,根据ID显示第二个下拉框的值。服务器响应页面的代码如下。

程序清单:Ajax02request/get/second.jsp

<%@ page contentType="text/html; charset=UTF-8" language="java"%>

<%

String idStr = (String)request.getParameter("id");

int id = idStr == null ? 1 : Integer.parseInt(idStr);

switch(id){

case 1:

out.println("上海$广州$北京");

break;

case 2:

out.println("华盛顿$纽约$加州");

break;

case 3:

out.println("东京$大板$福冈");

break;

}

%>

上面jsp页面作为服务器响应非常简单:先读取请求参数,当请求id1时,返回三个中国城市;当请求id2时,返回三个美国城市;当请求id3时,返回三个日本城市。

 

在浏览器中浏览该页面,并改变左边下拉列表的选中项,将看到下图效果:

 

 

  1. 使用POST方式

 

POST请求的适应性更广,可使用更大的请求参数。而且POST请求的请求参数在页面跳转时,不能在链接地址中直接看到,保密性更好。因此在使用Ajax发送请求时,尽量采用POST方式而不是GET方式发送请求。发送POST请求通常需要如下三个步骤:

  • 使用open方法打开连接时,指定使用POST方式发送请求。
  • 设置正确的请求头,POST请求通常应设置Content-Type请求头。
  • 发送请求,把请求参数转为查询字符串,将该字符串作为send()方法的参数。

对于上面的应用,使用POST方式实现,只需要改一个请求的发送方法,如下所示:

// 事件处理函数,当下拉列表选择改变时,触发该事件

function change(id) {

// 初始化XMLHttpRequest对象

createXMLHttpRequest();

// 设置请求响应的URL

var uri = "second.jsp";

// 设置处理响应的回调函数

xmlrequest.onreadystatechange = processResponse;

// 设置以POST方式发送请求,并打开连接

xmlrequest.open("POST", uri, true);

// 设置POST请求的请求头,表示数据被编码为名称/值对

xmlrequest.setRequestHeader("Content-Type"

, "application/x-www-form-urlencoded");

// 发送请求

xmlrequest.send("id="+id);

}

其余的部分则无须改变,应用的执行效果与采用GET方式发送请求的效果完全一样。事实上,即使采用POST方式发送请求,一样可以将请求参数附加在请求的URL之后。如果send方法没有请求参数,应传入null,因为有些浏览器规定了send方法必须传入参数。代码如下:

// 事件处理函数,当下拉列表选择改变时,触发该事件

function change(id) {

// 初始化XMLHttpRequest对象

createXMLHttpRequest();

// 设置请求响应的URL

var uri = "second.jsp?id="+id;

// 设置处理响应的回调函数

xmlrequest.onreadystatechange = processResponse;

// 设置以POST方式发送请求,并打开连接

xmlrequest.open("POST", uri, true);

// 设置POST请求的请求头

xmlrequest.setRequestHeader("Content-Type"

, "application/x-www-form-urlencoded");

// 发送请求

xmlrequest.send(null);

}

以上是关于谁知道怎么用ajax实现选择下拉框的时候动态从数据库读取数据吗的主要内容,如果未能解决你的问题,请参考以下文章

在jsp中如何实现加一个动态下拉框选择年份,并在当前页面显示相应的月份值?

ajax_get/post_两级联动

ASP实现两个select下拉框的联动

怎么用jquery实现 在一个下拉框中添加一个“其他”的选项来代表除去已选项的其余所有未选项

vue 实现下拉框动态获取年份

JSP 实现两个select下拉框的数据联动,要求根据第一个下拉式选择的内容联动第二个下拉式。需要从数据库中