EXT.NET(八)Combox 实现模糊异步查询

本文探讨了如何在COMBOX中实现类似百度和GOOGLE的AJAX模糊查询功能,并通过一个具体的C# WebHandler实例展示了如何从数据库获取数据并返回JSON格式结果。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

突然间想到百度和GOOGLE的AJAX模糊查询的功能。那就COMBOX中能不能实现呢?

查看资料

在数据源中多了一个

<Proxy>
<ext:HttpProxy Method="POST" Url="Plants.ashx" />
</Proxy>

估计是异步的东东。本人才浅

先建立一个

<%@ WebHandler Language="C#" Class="DataHandler" %>

using System;
using System.Web;
using System.Collections.Generic;
using Ext.Net;
using System.Data;

public class DataHandler : IHttpHandler {
public void ProcessRequest(HttpContext context)
{
if (!string.IsNullOrEmpty(context.Request["query"]))
{

string query = context.Request["query"];

context.Response.ContentType = "text/json";

DataTable table = new DAL.UserDAO().WorkNoList(query).Tables[0] ;

List<UserInfo> lst = new List<UserInfo>();

foreach (DataRow row in table.Rows)
{

UserInfo user = new UserInfo();

user.UserName = Convert.ToString(row["name"]);
//user.UserId = Convert.ToInt32(row["workno"]);
user.UserId = Convert.ToString(row["workno"]);
lst.Add(user);

}

string json = Ext.Net.JSON.Serialize(lst);

context.Response.Write(json);

}

else
{

context.Response.ContentType = "text/json";

DataTable table = new DAL.UserDAO().WorkNoList().Tables[0] ;

List<UserInfo> lst = new List<UserInfo>();

foreach (DataRow row in table.Rows)
{

UserInfo user = new UserInfo();

user.UserName = Convert.ToString(row["name"]);
//user.UserId = Convert.ToInt32(row["workno"]);
user.UserId = Convert.ToString(row["workno"]);
lst.Add(user);

}

string json = Ext.Net.JSON.Serialize(lst);

context.Response.Write(json);


}

}

public bool IsReusable
{
get
{
return false;
}
}
}

public class UserInfo
{
private string _UserName;

public string UserName
{
get { return _UserName; }
set { _UserName = value; }
}
private string _UserId;

public string UserId
{
get { return _UserId; }
set { _UserId = value; }
}


}

看看效果吧

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值