easyui combobox中的值是从数据库拿过来的,编辑easyui gridveiw时combobox定位gridveiw对应值

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了easyui combobox中的值是从数据库拿过来的,编辑easyui gridveiw时combobox定位gridveiw对应值相关的知识,希望对你有一定的参考价值。

easyui combobox中的值是从数据库拿过来的,编辑easyui gridveiw时combobox定位gridveiw对应值
就是选择gridveiw一行数据点击编辑按钮后出来编辑窗口,怎么样能让combobox也自动默认为所点gridveiw这一行中的这个值。 比如,下拉框中是男,女; 所点击的 gridveiw的哪一行的性别是女; 点编辑后combobox的值也变为女呢;

参考技术A 先定义一个性别的选择框,如下:
name:"gender",id:"gendere",fieldLabel:"用户性别",
mode: 'local',
triggerAction: 'all',
typeAhead: true,
lazyRender:true,
xtype:"combo",
emptyText:"--请选择--",
store: new Ext.data.ArrayStore(
id:2,
fields:['key','values'],
data:[[0,'男'],[1,'女']]
),
displayField:'values',
valueField:'key',
selectOnFocus:true

再定义点击gridview时的触发事件,如下,将点击那行的性别赋值给性别选择框:
userGrid.on('rowclick',function(grid,rowIndex,event)
var record = userGrid.getStore().getAt(rowIndex);
Ext.getCmp('gendere').setValue(record.get("gender"));
);
这样应该就可以显示出来了。追问

谢谢 我先试试

本回答被提问者和网友采纳

请问如何用easyui的combobox实现中文搜索

我想用easy ui 的combobox做中文搜索功能,使用的onchange事件reloader后显示出来的是valuefield。请问如何解决?

之前我和你遇到过一样的问题,不要使用onChange,使用loader,我用的是J2EE,不知道你用的是什么环境,但大体是差不多的,主要是JS和HTML部分,你可以试试:

需求:1、每输入一个字符,读取数据库查询15条近似数据2、读出数据后,按上、下键+回车键进行选择

【JavaScript】
//easyUI combobox中不要使用onChange来做读取数据库操作,有很多BUG,建议使用loader
var btsloader = function(param,success,error)

//获取输入的值
var q = param.q || "";

//此处q的length代表输入多少个字符后开始查询
if(q.length <= 0) return false;
$.ajax(
url:"<%=path%>/jsonObj/costAction_getJSONCostList",
type:"post",
data:
//传值,还是JSON数据
searchName:q
,

//重要,如果写jsonp会报转换错误,此处不写都可以
dataType:"json",
success:function(data)

//关键步骤,遍历一个MAP对象
var items = $.map(data.rows, function(item)
return
id:item.id,
name:item.text
;
);

//执行loader的success方法
success(items);
,

//异常处理
error:function(xml, text, msg)
error.apply(this, arguments);

);
;

【HTML】
<input id="costId" name="costId" class="easyui-combobox" style="width:250px;" data-options="
loader: btsloader,
mode: 'remote',
valueField: 'id',
textField: 'name'" />

【JAVA】public String getJSONCostList() throws UnsupportedEncodingException, JSONException
List<HashMap<String, Object>> jsonArr = new ArrayList<HashMap<String, Object>>();
List<Cost> list = costService.searchCosts(0, 14, searchName);
for(Cost c: list)
HashMap<String, Object> hm = new HashMap<String, Object>();
hm.put("id", c.getId());
hm.put("text", c.getBtsName());
jsonArr.add(hm);

HashMap<String, Object> hm = new HashMap<String, Object>();
hm.put("rows", jsonArr);
result = JSONObject.fromObject(hm);
return "ajax";


【struts.xml】
<package name="jsonObj" namespace="/jsonObj" extends="json-default">
<action name="*_*" class="1" method="2">
<result name="ajax" type="json">
<param name="root">result</param>
</result>
</action>
</package>

传入的JSON Object举例: "rows":["id":1,"text":"基站1","id":2,"text":"基站2"]追问

多谢,已经实现了。还有一个问题。就是我希望初始化combobox的时候就发起一个默认请求填充默认值。这个如何实现?

追答

试试初始化页面时定义一个JSON对象,或者用AJAX从后台获取一个JSON对象,再用$("#xxx").combobox("loadData", data);来加载这组数据

参考技术A easyui 的 combobox 本身是具有搜索功能的,听你的描述,似乎是要实现边输入边过滤的下拉菜单功能?那么就可以用下面这样的的写法,从服务器端搜索内容:
<input type="text" name="comboname" class="easyui-combobox" data-options="valueField:'id',textField:'name',editable:true,url:'/server/action'" value="$bean.comboname" />

这样就可以实现从“/server/action”获取json数据,并边输入边过滤的功能了。
同时,value="$bean.comboname"这个写法就能实现你想要的默认值功能。

以上是关于easyui combobox中的值是从数据库拿过来的,编辑easyui gridveiw时combobox定位gridveiw对应值的主要内容,如果未能解决你的问题,请参考以下文章

easyui中combobox 验证输入的值必须为选项框中的数据

Jquery 结合 easyUI 实现 当选择框中的值等于某一个值的时候,另一个combobox中的值发生变化。

easyui combobox模糊查询

关于easyui combobox

easyui combobox 设置值

jQuery easyui 中 combobox的事件处理吗