[原创]关于ExtJs.combo动态加载的实现_Android, Python及开发编程讨论区_Weblogic技术|Tuxedo技术|中间件技术|Oracle论坛|JAVA论坛|Linux/Unix技术|hadoop论坛_联动北方技术论坛  
网站首页 | 关于我们 | 服务中心 | 经验交流 | 公司荣誉 | 成功案例 | 合作伙伴 | 联系我们 |
联动北方-国内领先的云技术服务提供商
»  游客             当前位置:  论坛首页 »  自由讨论区 »  Android, Python及开发编程讨论区 »
总帖数
2
每页帖数
101/1页1
返回列表
0
发起投票  发起投票 发新帖子
查看: 4250 | 回复: 1   主题: [原创]关于ExtJs.combo动态加载的实现        下一篇 
java_along
注册用户
等级:上尉
经验:771
发帖:36
精华:0
注册:2014-2-17
状态:离线
发送短消息息给java_along 加好友    发送短消息息给java_along 发消息
发表于: IP:您无权察看 2014-3-21 23:27:24 | [全部帖] [楼主帖] 楼主

昨天发了个帖子是关于ExtJs动态加载数据。

但是昨天是把数据写死在store里,而不是从数据库里加载的,

这不免让大家感到有点美中不足,

今天,我再2个例子,是从后台取数据的。

1:直接从已有的json文件取得数据:

Ext.onReady(function(){
      var store=Ext.create("Ext.data.Store",{
            fields:[{
                  name:"key",
                  type:"auto"
            },{
            name:"value",
            type:"auto"
      }],
      proxy:{
            type:"ajax",
            url:"item.json",
            reader:{
                  type:'json',
                  root:'items'
            }
      },
      autoLoad:true
});
Ext.create("Ext.panel.Panel",{
      title:"aa",
      width:300,
      height:400,
      items:[{
            xtype:"combo",
            hideTrigger:true,
            store:store,
            displayField: 'key',
            valueField: 'value',
            minChars : 1,
            queryMode:"remote",
            editable:true,
            triggerAction:"all"
      }],
      renderTo:Ext.getBody()
}).show();
});


和上次的代码的区别就是: data不写死在store里,而是用proxy动态代理的读取器reader用ajax的方式去读取

item.json数据。

item.json:
{items:[{"key":"a1","value":"a1"},{"key":"a2","value":"a2"},{"key":"a3","value":"a3"},{"key":"a4","value":"a4"}]}


当然有了动态代理还是不够的,还需要把queryMode改为remote,就是远程的意思,还有个最重要的地方,就是minChars:1

为什么要加上这个参数呢?因为

北京联动北方科技有限公司

Extjs为我们提供的文档上已经写明,当你远程去获取data的时候,只有当你的char为4的时候,就是你输入的字符至少为4个的时候才触发。我们把他改为输入1个字符就加载data。

好,上面就是动态从json文件加载数据。

2:从mysql数据库动态加载数据:

drop table test_item;
create table test_item(
t_id int primary key,
t_key varchar(20),
t_value varchar(20)
)
insert into test_item(t_id,t_key,t_value) values(1,"aaaa","aa");
insert into test_item(t_id,t_key,t_value) values(2,"aaaa2","aa");
insert into test_item(t_id,t_key,t_value) values(3,"aaaa3","aa");
insert into test_item(t_id,t_key,t_value) values(4,"aaaa4","aa");
insert into test_item(t_id,t_key,t_value) values(5,"aaaa5","aa");
insert into test_item(t_id,t_key,t_value) values(6,"aaaa6","aa");
insert into test_item(t_id,t_key,t_value) values(7,"bbb","aa");
insert into test_item(t_id,t_key,t_value) values(8,"bbb","aa");
insert into test_item(t_id,t_key,t_value) values(9,"bbb","aa");
insert into test_item(t_id,t_key,t_value) values(10,"bb","aa");
insert into test_item(t_id,t_key,t_value) values(11,"bbbbbb","aa");
insert into test_item(t_id,t_key,t_value) values(12,"bbbbb","aa");


先创建数据库 加点数据。

然后动态访问servlet取得json值。

先给大家看下效果:

输入a

北京联动北方科技有限公司

输入b

北京联动北方科技有限公司

看下js代码

与上面的访问item.json的代码相差不大,有2个地方需要改动

url:"test.do" 前面是访问item.json,而这里需要访问我们自己的servlet。

还有个就是加个参数 queryParam:”key”, 当你加了这个参数后,

当你输入a时,js代码���通过ajax访问test.do,并且带式参数key=a;

当然queryParam后面不一定是key,你可以随便写,只要在servlet代码做相应的处理就可以了。




赞(0)    操作        顶端 
java_along
注册用户
等级:上尉
经验:771
发帖:36
精华:0
注册:2014-2-17
状态:离线
发送短消息息给java_along 加好友    发送短消息息给java_along 发消息
发表于: IP:您无权察看 2014-3-21 23:29:51 | [全部帖] [楼主帖] 2  楼

有需要的人可以私下交流,QQ840727854

有问必答。

学习就是慢慢去积累



赞(0)    操作        顶端 
总帖数
2
每页帖数
101/1页1
返回列表
发新帖子
请输入验证码: 点击刷新验证码
您需要登录后才可以回帖 登录 | 注册
技术讨论