jquery easyui 使用 combobox动态加载数据

首先引入相关js 和css

   
    
    
    

前端代码



    
一级别分类: 二级别分类:

服务器端代码

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Data;
using System.Web.Script.Serialization;
namespace jqeasyui
{
    /// 
    /// Type 的摘要说明
    /// 
    public class Type : IHttpHandler
    {

        public void ProcessRequest(HttpContext context)
        {
            context.Response.ContentType = "text/plain";
            int tid = 0;
            //判断是否第一次请求
            if (!string.IsNullOrEmpty(context.Request["id"]))
            {
                
                tid = int.Parse(context.Request["id"]);//获取父类中当前选中项目的id
            }
            web2Bll.TypeInfoBLL tpbll = new web2Bll.TypeInfoBLL();
            List list = new List();
            list=tpbll.GetListTypeInfo("  parentId="+tid,"");
            List listModel = new List();//创建一个自定义类型的集合  ,类中属性 id 和 text 需要和前端 valueField 和 textField 属性中的值一样
            foreach (web2Model.TypeInfo typeInfo in list)
            {
                listModel.Add(new TypeModel() { 
                 id=typeInfo.TypeId,  
                 text=typeInfo.TitleName
                });
            }
            JavaScriptSerializer js = new JavaScriptSerializer();//序列化集合转换成json 
            context.Response.Write(js.Serialize(listModel));//返回到前端 
        }

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

combobox的其他方法,属性,事件

属性
groupField:
参数类型:string
说明:指示要被分组的字段。该属性自版本 1.3.4 起可用。
默认值:null
groupFormatter:
参数类型:function(group)
说明:返回要显示在分组项目上的分组文本。该属性自版本 1.3.4 起可用。
例如:

$('#cc').combobox({
	groupFormatter: function(group){
		return '' + group + '';
	}
});

mode
参数类型:string
说明:定义在文本改变时如何加载列表数据。如果组合框(combobox)从服务器加载就设置为 ‘remote’。当设置为 ‘remote’ 模式时,用户输入的值将会被作为名为 ‘q’ 的 http 请求参数发送到服务器,以获取新的数据。
默认值:local

method:
参数类型:string
说明:用来检索数据的 http 方法。
默认值:post
data:
参数类型: arr
说明:被加载列表数据
例子;


默认值:null
filter:
参数类型:function
说明:定义如何呈现行。该函数有一个参数:row。
例子:

$('#cc').combobox({
	filter: function(q, row){
		var opts = $(this).combobox('options');
		return row[opts.textField].indexOf(q) == 0;
	}
});

formatter
参数:function(row) row为行内容
说明:如何呈现行
例子

$('#cc').combobox({
	formatter: function(row){
		var opts = $(this).combobox('options');
		return row[opts.textField];
	}
});

loader:
参数:function(param,success,error)
说明:定义如何从远程服务器加载数据。返回 false 则取消该动作。该函数有下列参数:
param:要传到远程服务器的参数对象。
success(data):当获取数据成功时将被调用的回调函数。
error():当获取数据失败时将被调用的回调函数。
默认值:json loader
事件
onBeforeLoad
参数:param
说明:在请求加载数据之前触发,返回 false 则取消加载动作。
例子

 
$('#cc').combobox({
	onBeforeLoad: function(param){
		param.id = 2;
		param.language = 'js';
	}
});

onLoadError
说明:当远程数据加载失败时触发。
onUnselect
参数:record
说明:当用户取消一个列表项时触发。

方法
getData
说明:返回加载的数据。
loadData
参数 data
说明:加载本地列表数据。

reload
参数: url
说明:请求远程的列表数据。传 ‘url’ 参数来重写原始的 URL 值。
例子:

$('#cc').combobox('reload');  // reload list data using old URL
$('#cc').combobox('reload','get_data.php');  // reload list data using new URL

setValues
参数 values
设置组合框(combobox)值的数组值。
如:

$('#cc').combobox('setValues', ['001','002']);

setValue
设置组合框值
getValue
获取组合框的值

var t1=$('#cc').combobox('getValue');

select , unSelect
获取选中的项目 ,取消选中的项目
clear
清空所有的项目

你可能感兴趣的:(jquery easyui 使用 combobox动态加载数据)