ajax实现动态下拉框示例
许多页面上都涉及有下拉框,即select标签。对于简单的下拉框,被选择的数据是不需要改变的,我们可以用<option></option>写死。这样下拉框的数据永远都是那几条。
示例
<select> <option>信息一</option> <option>信息二</option> <option>信息三</option> <option>信息四</option> </select>
有些项目或者工程是需要将数据库中的数据呈现出来并提供选择的,下拉的内容会随数据库中数据的变化而变化。我们有asp组件可以帮我们做这这件事情,DropDownList组件,只需要将数据库中查询得到的数据添加进该组件中,在前台即可以显示出动态下拉的效果。如果想更有新意,不依赖于传统组件,ajax就是个不错的选择。狼蚁网站SEO优化一步步来通过ajax实现动态下拉的效果。
1.js发出ajax请求
$(document).ready(function () { $.ajax({ timeout: 3000, async: false, type: "POST", url: "WareHouse.ashx", dataType: "json", data: { warehouse: $("#issued_sub_key_c").val(), }, suess: function (data) { for (var i = 0; i < data.length; i++) { $("#issued_sub_key_c").append("<option>" + data[i].Name + "</option>"); } } }); });
ajax请求WareHouse.ashx(一般处理程序)来获得数据,请求成功后将返回的json数据附加到id为issued_sub_key_c的select标签。值得注意的是这里将async的属性改为了false,async的默认状态为true,即为异步。值改为false就是同步了。当async为false的时候,ajax请求完数据之前,浏览器一直处于锁死状态,这样会让使用者认为程序崩溃了,所以就人为的添加了一个超时(timeout),这样就不会出现程序崩溃的假象。回到话题开始,为什么要将async改为false呢?原因就是当ajax是异步请求的时候进入到页面后出现下拉框数据还未同步,下拉框是空白数据(可以自己体验体验)。所以我们需要利用同步的特性并配合超时来完成下拉框的数据同步。
2.一般处理程序从数据库返回的数据是List<string>类型,我们需要自己定义一个toJson()方法将list转化为json数据,然后返回json数据。
public string toJson(List<string> str) { StringBuilder json = new StringBuilder(); if (str == null) { return "null"; } json.Append("["); foreach (var item in str) { json.Append("{\"Name\":\""); json.Append(item); json.Append("\"},"); } return json.ToString().Substring(0, json.ToString().LastIndexOf(",")) + "]"; } /得到并关联仓库(select标签)/ public void ProcessRequest(HttpContext context) { SubinventoryDC subinventorydc = new SubinventoryDC(); List<string> list = new List<string>(); list = subinventorydc.getAllSubinventory(); string json = toJson(list); context.Response.ContentType = "text/plain"; context.Response.Write(json); }
3.前台页面前台只需要定义一个id为issued_sub_key_c的select标签。注意select标签须得有一个name,后台正是通过name来取得选中数据的值。取值方法Request.Form["issued_sub_key_c"]。
<select id="issued_sub_key_c" name="issued_sub_key_c"> </select>
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持狼蚁SEO。
编程语言
- 如何快速学会编程 如何快速学会ug编程
- 免费学编程的app 推荐12个免费学编程的好网站
- 电脑怎么编程:电脑怎么编程网咯游戏菜单图标
- 如何写代码新手教学 如何写代码新手教学手机
- 基础编程入门教程视频 基础编程入门教程视频华
- 编程演示:编程演示浦丰投针过程
- 乐高编程加盟 乐高积木编程加盟
- 跟我学plc编程 plc编程自学入门视频教程
- ug编程成航林总 ug编程实战视频
- 孩子学编程的好处和坏处
- 初学者学编程该从哪里开始 新手学编程从哪里入
- 慢走丝编程 慢走丝编程难学吗
- 国内十强少儿编程机构 中国少儿编程机构十强有
- 成人计算机速成培训班 成人计算机速成培训班办
- 孩子学编程网上课程哪家好 儿童学编程比较好的
- 代码编程教学入门软件 代码编程教程