起步软件技术论坛
搜索
 找回密码
 注册

QQ登录

只需一步,快速开始

查看: 4459|回复: 7

[结贴] 怎样通过label、input和查询按钮控件,然后输入的查询条件....

[复制链接]

56

主题

111

帖子

285

积分

中级会员

Rank: 3Rank: 3

积分
285
QQ
发表于 2018-5-20 23:59:20 | 显示全部楼层 |阅读模式
Grid绑定了bizdata。不想用系统封装好的bizfilter组件;想在前台自己放几个label、input和查询按钮控件,然后输入的查询条件,通过单击查询按钮,
能过滤出来查询的记录。怎样实现?

91

主题

13万

帖子

3万

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
36185
发表于 2018-5-21 09:48:34 | 显示全部楼层
那就自己获取input中输入的值,通过data的setFilter方法设置过滤调用并过滤数据
setFilter方法在API中有说明
远程的联系方法QQ1392416607,添加好友时,需在备注里注明其论坛名字及ID,公司等信息
发远程时同时也发一下帖子地址,方便了解要解决的问题  WeX5教程  WeX5下载



如按照该方法解决,请及时跟帖,便于版主结贴
回复 支持 反对

使用道具 举报

56

主题

111

帖子

285

积分

中级会员

Rank: 3Rank: 3

积分
285
QQ
 楼主| 发表于 2018-5-21 16:19:47 | 显示全部楼层
这段代码红色部分,报错!

Model.prototype.button1Click = function(event){
                var curData = this.comp('mainData');
                var input3 = this.comp('input3').val();
                curData.setFilter('filter1', 'CA_BYJSC.fSBBH = :input3');
                curData.refreshData();
                curData.filters.clear();
        };

怎样把input输入控件的值,传入setFilter的第二个参数。
回复 支持 反对

使用道具 举报

91

主题

13万

帖子

3万

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
36185
发表于 2018-5-21 16:24:31 | 显示全部楼层
curData.setFilter('filter1', 'CA_BYJSC.fSBBH ='"+input3+"'');
远程的联系方法QQ1392416607,添加好友时,需在备注里注明其论坛名字及ID,公司等信息
发远程时同时也发一下帖子地址,方便了解要解决的问题  WeX5教程  WeX5下载



如按照该方法解决,请及时跟帖,便于版主结贴
回复 支持 反对

使用道具 举报

56

主题

111

帖子

285

积分

中级会员

Rank: 3Rank: 3

积分
285
QQ
 楼主| 发表于 2018-5-22 09:52:37 | 显示全部楼层
前台js代码不报错,点击查询按钮报错,
刷新数据失败! ,
执行KSQL出错, KSQL: SELECT CA_BYJSC.* FROM CA_BYJSC CA_BYJSC WHERE ((CA_BYJSC.fRQSJ >=justep.Date.fromString("2017-05-22T09:47:04.331Z","yyyy-MM-dd hh:mm")) AND (CA_BYJSC.fRQSJ <=justep.Date.fromString("2018-05-22T09:47:07.882Z","yyyy-MM-dd hh:mm")) AND (CA_BYJSC.fSBBH ="byj001") AND (CA_BYJSC.fSBMC ="包衣机001")) LIMIT 0, 20
--> sql:
--> binds: []

编码:JUSTEP150210
[url=]显示详细[/url]


[url=]前台js代码:[/url]
[url=]        Model.prototype.button1Click = function(event){
                var curData = this.comp('mainData');
                var input6 = this.comp('input6').val();
                var input2 = this.comp('input2').val();
                var input3 = this.comp('input3').val();
                var input5 = this.comp('input5').val();
               
                curData.setFilter('filter1', "CA_BYJSC.fRQSJ >=" + "justep.Date.fromString(" + '"' + input6 + '"' + ',' + '"' + 'yyyy-MM-dd hh:mm' + '"' + ")" );//input6 是datatime类型
                curData.setFilter('filter2', "CA_BYJSC.fRQSJ <=" + "justep.Date.fromString(" + '"' + input2 + '"' + ',' + '"' + 'yyyy-MM-dd hh:mm' + '"' + ")" );//input2 是datatime类型
                curData.setFilter('filter3', 'CA_BYJSC.fSBBH =' + '"'+ input3 + '"');
                curData.setFilter('filter4', 'CA_BYJSC.fSBMC =' + '"'+ input5 + '"');
                curData.refreshData();
                curData.filters.clear();
        };

是前台js代码的问题,还是其他原因?
[/url]



tu1.jpg
tu2.jpg
回复 支持 反对

使用道具 举报

56

主题

111

帖子

285

积分

中级会员

Rank: 3Rank: 3

积分
285
QQ
 楼主| 发表于 2018-5-22 09:54:43 | 显示全部楼层
详细信息

隐藏详细
java.lang.reflect.InvocationTargetException
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
at java.lang.reflect.Method.invoke(Method.java:497)
at com.justep.system.action.Engine.invokeActions(Native Method)
at com.justep.system.action.Engine.invokeActions(Unknown Source)
at com.justep.business.server.BusinessServer.doAction(Unknown Source)
at com.justep.business.server.BusinessServer.doExcute(Unknown Source)
at com.justep.business.server.BusinessServer.excute(Unknown Source)
at com.justep.business.server.BusinessServer.excute(Unknown Source)
at com.justep.business.server.BusinessServerServlet.execService(Unknown Source)
at com.justep.business.server.BusinessServerServlet.service(Unknown Source)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:723)
at com.justep.x.bs.BusinessServerServlet.service(Unknown Source)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:723)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:290)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:233)
at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:191)
at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:127)
at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:103)
at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:109)
at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:293)
at org.apache.coyote.http11.Http11Processor.process(Http11Processor.java:861)
at org.apache.coyote.http11.Http11Protocol$Http11ConnectionHandler.process(Http11Protocol.java:606)
at org.apache.tomcat.util.net.JIoEndpoint$Worker.run(JIoEndpoint.java:489)
at java.lang.Thread.run(Thread.java:745)
Caused by: com.justep.exception.BusinessException: 编码: JUSTEP150210; 提示: 执行KSQL出错, KSQL: SELECT CA_BYJSC.* FROM CA_BYJSC CA_BYJSC WHERE ((CA_BYJSC.fRQSJ >=justep.Date.fromString("2017-05-22T09:47:04.331Z","yyyy-MM-dd hh:mm")) AND (CA_BYJSC.fRQSJ <=justep.Date.fromString("2018-05-22T09:47:07.882Z","yyyy-MM-dd hh:mm")) AND (CA_BYJSC.fSBBH ="byj001") AND (CA_BYJSC.fSBMC ="包衣机001")) LIMIT 0, 20
--> sql:
--> binds: []
at com.justep.exception.BusinessException.create(Unknown Source)
at com.justep.system.data.impl.TableUtilsImplement.ksqlSelect(Unknown Source)
at com.justep.system.data.impl.TableUtilsImplement.ksqlSelect(Unknown Source)
at com.justep.system.data.impl.TableUtilsImplement.ksqlSelect(Unknown Source)
at com.justep.system.data.BizData.query(Unknown Source)
at BizProcedure.query(BizProcedure.java:12)
... 27 more
Caused by: com.justep.exception.KSQLException: 编码: JUSTEP154115; 提示: KSQL语法错误, J >=justep.Date^^.fromString("20中未找到需要的元素, 位置78期望是)
at com.justep.exception.KSQLException.create(Unknown Source)
at com.justep.system.ksql.token.TokenManager.matchToken(Unknown Source)
at com.justep.system.ksql.token.TokenManager.match(Unknown Source)
at com.justep.system.ksql.parser.AbstractParser.unaryExpression(Unknown Source)
at com.justep.system.ksql.parser.AbstractParser.multiExpression(Unknown Source)
at com.justep.system.ksql.parser.AbstractParser.addExpression(Unknown Source)
at com.justep.system.ksql.parser.AbstractParser.compExpression(Unknown Source)
at com.justep.system.ksql.parser.AbstractParser.notExpression(Unknown Source)
at com.justep.system.ksql.parser.AbstractParser.andExpression(Unknown Source)
at com.justep.system.ksql.parser.AbstractParser.orExpression(Unknown Source)
at com.justep.system.ksql.parser.AbstractParser.unaryExpression(Unknown Source)
at com.justep.system.ksql.parser.AbstractParser.multiExpression(Unknown Source)
at com.justep.system.ksql.parser.AbstractParser.addExpression(Unknown Source)
at com.justep.system.ksql.parser.AbstractParser.compExpression(Unknown Source)
at com.justep.system.ksql.parser.AbstractParser.notExpression(Unknown Source)
at com.justep.system.ksql.parser.AbstractParser.andExpression(Unknown Source)
at com.justep.system.ksql.parser.AbstractParser.orExpression(Unknown Source)
at com.justep.system.ksql.parser.AbstractParser.conditionExpression(Unknown Source)
at com.justep.system.ksql.parser.AbstractParser.whereExpression(Unknown Source)
at com.justep.system.ksql.parser.AbstractParser.selectSentenceNode(Unknown Source)
at com.justep.system.ksql.parser.QueryParser.start(Unknown Source)
at com.justep.system.ksql.parser.QueryParser.start(Unknown Source)
at com.justep.system.ksql.parser.AbstractParser.parse(Unknown Source)
... 32 more
回复 支持 反对

使用道具 举报

91

主题

13万

帖子

3万

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
36185
发表于 2018-5-22 10:52:18 | 显示全部楼层
justep.Date.fromString是js函数不能在ksql中用

可以在js中通过js转换用变量的方式在ksql中用,或者用ksql提供的函数
ksql.png
远程的联系方法QQ1392416607,添加好友时,需在备注里注明其论坛名字及ID,公司等信息
发远程时同时也发一下帖子地址,方便了解要解决的问题  WeX5教程  WeX5下载



如按照该方法解决,请及时跟帖,便于版主结贴
回复 支持 反对

使用道具 举报

56

主题

111

帖子

285

积分

中级会员

Rank: 3Rank: 3

积分
285
QQ
 楼主| 发表于 2018-5-23 10:34:29 | 显示全部楼层
找到一个简单的方法:

Model.prototype.button1Click = function(event){
                var xh = this.comp('input1').val();
                var xm = this.comp('input2').val();
                var curData = this.comp('mainData');
                curData.setFilter('filter2', "CA_XSXXB.fXH = :xuehao and CA_XSXXB.fXM = :xingming");
                curData.filters.setStringVar('xuehao',xh);
                curData.filters.setStringVar('xingming',xm);
                curData.refreshData();
                curData.filters.clear();
        };
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

本版积分规则

小黑屋|手机版|X3技术论坛|Justep Inc.    

GMT+8, 2025-7-11 10:14 , Processed in 0.067837 second(s), 27 queries .

Powered by Discuz! X3.4

© 2001-2013 Comsenz Inc.

快速回复 返回顶部 返回列表