http://www.jeasyui.net/demo/488.html
Basic ComboBox - jQuery EasyUI DemoType in ComboBox to try auto complete.
========
http://www.jeasyui.net/plugins/169.html
扩展自 $.fn.combo.defaults。通过 $.fn.combobox.defaults 重写默认的 defaults。
组合框(combobox)显示一个可编辑的文本框和下拉列表,用户可以从下拉列表中选择一个或多个值。用户可以直接输入文本到列表的顶部,或者从列表中选择一个或多个现成的值。
依赖
combo
用法
从带有预定义结构的 元素创建组合框(combobox)。
从 标记创建组合框(combobox)。
使用 javascript 创建组合框(combobox)。
$('#cc').combobox({ url:'combobox_data.json', valueField:'id', textField:'text' });创建两个依赖的组合框(combobox)。
json 数据格式的示例:
[{
“id”:1,
“text”:“text1”
},{
“id”:2,
“text”:“text2”
},{
“id”:3,
“text”:“text3”,
“selected”:true
},{
“id”:4,
“text”:“text4”
},{
“id”:5,
“text”:“text5”
}]
========
https://www.cnblogs.com/goloving/p/7115792.html
一、easyUI中select下拉框动态添加option选项
问题:想在combobox的下拉项里动态添加一些内容,但是添加不成功。因为jquery easyui的下拉列表combobox是用DIV模拟的(其实看看它的样式就应该想到)
解决方法:
1、一个空下拉框,注意不能加class=“easyui-combobox”,否则不生效
//注意class不能加easyui-combobox2、为下拉框添加子项:利用文档碎片
var fragment = document.createDocumentFragment();
for(var i=1;i<25;i++){
var option = document.createElement(“option”);
option.innerHTML = i + “点”;
$(option).attr(“value”,i);
fragment.appendChild(option);
}
$("#selectInfo1").append(fragment);
$("#selectInfo1").combobox({});
3、将下拉框转化为easyUI中的combobox
$("#selectInfo1").combobox({});
只要填充好数据,再去转化那就可以了。
二、Combobox用法和方法参数:
1、 需要引入class=" easyui-combobox”
2、 参数设置需要在data-options中设置
3、 属性参数配置:
valueField:基础数据值名称绑定到Combobox(提交值)
textField:基础数据的字段名称绑定的Combobox(显示值)
mode:定义当文本改变时如何加载列表数据,当设置为remote模式下,什么类型的用户将被发送http请求参数名为’q’的服务器,以获取新的数据。
url:从远程URL来加载列表数据
method:http方法检索列表数据
data:列表中被加载的数据
filter:定义如何过滤本地数据“模式”设置为’local’
formatter:定义如何呈现行
loader:定义如何从远程服务器加载数据
常用属性:
4、 事件:
onBeforeLoad(param): 操作之前将数据加载,返回false就取消这个荷载作用
onLoadSuccess():触发时,远程数据加载成功
onLoadError:触发时,远程数据加载错误
ONSELECT:触发,当用户选择一个列表项
onUnselect:触发,当用户取消选择一个列表
5、方法:
options():返回选择对象
getData():返回加载的数据
loadData(data):加载列表数据
reload(url):重新加载远程数据列表
setValues(values):设置combobox的值数组
setValue(value):设置combobox的值
clear():清空combobox的值
select(value):选中指定的值
unselect(value):取消指定的值
代码实例
combobox//设置下拉框的值
function setValue(){
$("#cc").combobox(“setValue”,“动态添加的列表值”);
}
//获取当前选择的值
function getValue(){
var selectText=$("#cc").combobox(“getValue”);
alert(“当前选择的是:”+selectText);
}
//禁用当前选择框
function disable(){
$("#cc").combobox(“disable”);
}
//启用当前选择框
function enable(){
$("#cc").combobox(“enable”);
}
$(’#cc1’).combobox({
filter: function(q, row){
var opts = $(this).combobox(‘options’);
return row[opts.textField].indexOf(q) == 0;
},
formatter: function(row){
var opts = $(this).combobox(‘options’);
return row[opts.textField];
}
});
单项选择的ComboBox:
Alabama North Carolina North Dakota Ohio Oklahoma Oregon本地数据源的Combobox
来源网页数据的Combobox
多项选择的ComboBox:
========
https://www.cnblogs.com/hailexuexi/p/8119439.html
reload 方法
javascript代码
//指定id 和 text 否则始终选择第一个
$('#contact_city').combobox({
valueField:'id',
textField:'text'
});
$('#contact_province').combobox({
onSelect: function (data) {var url = "Ajax-index.php?module=Contact&action=Ajax_Contact_Province_Change"+"&contact_province=" +data.text;
$('#contact_city').combobox('reload', url);
}
});
php代码
$province =trim($_GET['contact_province']);
$select="SELECT p.province,c.id,c.city,p.provinceid from province as p JOIN city as c ON p.provinceid = c.provinceid where p.province='" . $province . "'";
r e s u l t = result= result=db->query($select);
S e l e c t O p t i o n = " " ; w h i l e ( Select_Option=""; while( SelectOption="";while(row= d b − > f e t c h a r r a y ( db->fetch_array( db−>fetcharray(result)){
k e y = key= key=row[1];
v a l u e = value= value=row[2];
if($Select_Option==""){
$Select_Option= '{"id":"'.$key.'","text":"'.$value.'"}' ;
}else{
$Select_Option=$Select_Option .",". '{"id":"'.$key.'","text":"'.$value.'"}' ;
}
}
$Select_Option="[" . $Select_Option ."]";
echo $Select_Option;
loadData 方法
javascript
$(function(){
$(’#contact_city’).combobox({
valueField:‘id’,
textField:‘text’,
editable:false //是否可编辑
});
})
$(document).ready(function () {
$("#contact_province").combobox({
onChange: function (newVal,oldVal) {
var contact_province=newVal;
$.ajax({
type: "POST",
url: "Ajax-index.php?module=<{$module_name}>&action=Ajax_Contact_Province_Change",
dataType: "json",
data: {"contact_province":contact_province },
beforeSend: function(){
//$('').addClass("loading").html("加载中...").css("color","#999").appendTo('.sub1');
},
success: function(json){
if(json.success==1){
//alert(json.msg);
var data = $.parseJSON(json.msg);
$("#contact_city").combobox("loadData", data);
$("#contact_city ").combobox('select',data[0].text);//默认选中第一项
}else{
$.messager.alert('消息','数据加载失败!','error');
return false;
}
}
});
}
});
});
PHP代码
$province =trim($_POST['contact_province']);
$select="SELECT p.province,c.city,p.provinceid from province as p JOIN city as c ON p.provinceid = c.provinceid where p.province='" . $province . "'";
$result=$db->query($select);
$Select_Option="";
while($row=$db->fetch_array($result)){
$value=$row[1];
if($Select_Option==""){
$Select_Option= '{"id":"'.$value.'","text":"'.$value.'"}' ;
}else{
$Select_Option=$Select_Option .",". '{"id":"'.$value.'","text":"'.$value.'"}' ;
}
}
$Select_Option="[" . $Select_Option ."]";
$arr['success'] = 1;
$arr['msg'] = $Select_Option;
echo json_encode($arr);
====
Easyui combobox 始终选择第一个的问题
//必须指定 id 和 text
$(’#contact_city’).combobox({
valueField:‘id’,
textField:‘text’,
});
========
今天在做下拉框问题的时候碰到选择的值和显示的值的问题,
$(’#combobox’).combobox(‘getText’); 所有选中的现在的值
$(’#combobox’).combobox(‘getValue’); 获取选中值的value属性。
$(’#combobox’).combobox(‘getValues’); 获取选中的多个值 取出的值的类型为数组还是对象,傻傻分不清楚
jq后添加到页面中的combobox要重新初始化一下,要不然不会生效,下边是设置初始值
$(document).ready(function(){
$('#combobox').combobox({
editable:false,
multiple:true,
multiline:true,
});
})
$('#combobox').combobox('setValues',[])
========
https://blog.csdn.net/sd6275832ght/article/details/83992293
首先引入相关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
清空所有的项目
========