找回密码
 立即注册

QQ登录

只需一步,快速开始

postmanlly
社区贡献组   /  发表于:2015-6-24 18:32:00
51#
根据您提供的方法可以实现导出了,并且也解决了无规则分页的问题,非常感谢!
另外,js里获取不到参数的值字段问题还请能与美国研发同事沟通解决,谢谢~~
回复 使用道具 举报
frank.zhang
社区贡献组   /  发表于:2015-6-25 09:37:00
52#
您好,
非常感谢您对我们的支持和理解。
如果这个问题有进一步的进展,我会第一时间通知您。
回复 使用道具 举报
frank.zhang
社区贡献组   /  发表于:2015-7-1 11:00:00
53#
您好,
取参数的值字段,使用的方法是:
1.使用JS从前台取到选择的label
  1.     <script>
  2.             function appendParam() {
  3.                    
  4.                     var arr = [];
  5.                    
  6.                     arr.push($("#parametersPane .parameterTextBox").val());

  7.                     arr.push($("#parametersPane .parameterComboBox option:selected" ).text());
  8.                    
  9.             $("#parametersPane .parameterListBox input:checked").each(
  10.                            function () {
  11.                                    var t = $(this).next().text();
  12.                                    arr.push(t);
  13.                            }
  14.                    );
  15.                    
  16.             $('#subForm').append('<input type="hidden" name="paramCount" value="' + arr.length + '">');

  17.             arr.forEach(function (item, i, arr) {
  18.                     $('#subForm').append('<input type="hidden" name="param' + i + '" value="' + item + '">');
  19.             });
  20.             return true;
  21.         }
  22.     </script>
复制代码

2.在后台参数取到label和value的对应关系
  1.             var paramsInReport = _reportDef.Report.ReportParameters[2].ValidValues;
  2.             Dictionary<string, string> allValidParams = new Dictionary<string, string>();
  3.             foreach (var param in paramsInReport.ParameterValues)
  4.             {
  5.                 var p = (ParameterValue)param;
  6.                 allValidParams.Add(p.Label, p.Value);
  7.             }
复制代码

3.将value赋值给报表
  1.             for (int i = 0; i < paramCount; i++)
  2.             {
  3.                 string paramKey = "param{0}";
  4.                 if (i < 2)
  5.                 {
  6.                     numberParam = i;
  7.                 }
  8.                 else
  9.                 {
  10.                     numberParam = 2;
  11.                 }
  12.                 paramKey = string.Format(paramKey, i);
  13.                 string param = Request[paramKey];
  14.                 if (numberParam < 2)
  15.                 {
  16.                     _reportDef.Report.ReportParameters[numberParam].DefaultValue.Values.Add(param);
  17.                 }
  18.                 else
  19.                 {
  20.                     if (allValidParams.ContainsKey(param))
  21.                         _reportDef.Report.ReportParameters[numberParam].DefaultValue.Values.Add(allValidParams[param]);
  22.                 }
  23.             }
复制代码


效果截图:



示例代码:

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有帐号?立即注册

x
回复 使用道具 举报
postmanlly
社区贡献组   /  发表于:2015-12-18 17:07:00
54#
你好,
https://sas.grapecity.com/deactivation 打不开了,我们这边要Deactive.
回复 使用道具 举报
iceman
社区贡献组   /  发表于:2015-12-21 16:57:00
55#
回复 54楼postmanlly的帖子

请问网址打不开目前报什么错误?网络原因还是?我们目前可以正常打开
回复 使用道具 举报
123456
您需要登录后才可以回帖 登录 | 立即注册
返回顶部