需求

润乾报表的标签需要在jsf页面中和其他填报控件一起使用,润乾报表负责展现录入部分数据,并且这部分数据和页面的其它控件的数据存在前台和后台的交互。

问题

润乾报表在前台会生成自己的form,嵌入到的jsf的form标签中后,出现两个form嵌套的情况,造成报表无法填报和提交。

Jsf1.1版本本身不支持两个form的提交,所以form并列的方式也不可取。

可行解决方案:

1:填报表解析后本身不作为一个form,当我们点击提交的时候动态生成一个iframe,这个iframe中生写一个form,再把报表数据写到这个form中去做提交保存操作。

2:可选择是否生成form。

1)当润乾填报表使用在jsf的form标签中时,选择不生成form,然后可以通过js方法遍历获取到填报的数据,将数据和其他填报套件的数据一同提交到后台处理。

2)当润乾填报表单独使用时,不嵌套在jsf的form标签中,选择生成form,润乾填报表可以填报保存数据。

实现的解决方案:

对于其它填报控件中数据需要和润乾填报的数据进行交互的情况,前台获取润乾填报表数据,跟用户自己开发的填报控件数据一同提交不失为一种很好的方法,因为这样数据可以直接进入客户的业务处理类进行交互处理。

目前润乾报表已经支持第二种处理方法,即选择不生成form标签。使用方法:

<f:view>

<h:form>

<f:subview
id=“a”>

<f:verbatim>

<report:html
name=“report1″
reportFileName=“mydataset.raq”

funcBarLocation=“top”

needPageMark=“yes”

needPrint=“yes”

needSaveAsWord=“yes”

submit=“保存“

generateParamForm=”no”

width=“-1″

reportEnterUrl=“add.jsf”

generateSubmitForm=“no”

exceptionPage=“/reportJsp/myError2.jsp”/>

</f:verbatim>

</f:subview>

<input
name=“get1″
value=“查看值1″
type=“button”
type=“form1″
onClick=“getInputData()”>

<input
name=“get2″
value=“查看值2″
type=“button”
type=“form1″
onClick=“getCycle()”>

</h:form>

</f:view>

遍历报表填报表中输入的数据,包括真实值,显示值,单元格与数据库字段的对应关系(单元格定义的html事件)的js:

<script type=”text/javascript”>

function getCycle(){  //cellName为扩展格的名称,n为扩展出几个,reportName为tag的name属性

_submitEditor(document.getElementById(‘report1′));

var rpt = document.getElementById(“report1″);

//获得报表的行数

var rowCount = rpt.rows.length;

//alert(rowCount);

//获得报表的列数

var colCount = rpt.rows[0].cells.length;

//alert(colCount);

for(var j=1;j<=colCount;j++){

var cname=”";

if(j==1) cname=”report1_A”;

if(j==2) cname=”report1_B”;

if(j==3) cname=”report1_C”;

if(j==4) cname=”report1_D”;

if(j==5) cname=”report1_E”;

if(j==6) cname=”report1_F”;

if(j==7) cname=”report1_G”;

for(var i=1;i<=rowCount;i++){

var cname1=cname+i.toString();

if(document.getElementById (cname1).modifiable){

var tempValue = document.getElementById (cname1).value; //获得单元格的真实值

      alert(“单元格”+i+”的真实值是”+tempValue);

var xsValue = document.getElementById (cname1).innerText; //获得单元格的显示值

      alert(“单元格”+i+”的显示值是”+xsValue);

var dbfiled = document.getElementById (cname1).dbfiled; //获得单元格的定义的html事件名称

      alert(“单元格”+i+”的数据字段是”+dbfiled);

}

}

}

}

//–>

</script>

总结:

数据交互即可后台处理,也可前台处理,以上方案适用于jsf使用自定义填报套件和润乾填报表一同进行数据保存处理或者jsp中form中使用润乾填报表的业务场景

润乾报表JSF FORM 标签中使用填报表解决方案的更多相关文章

  1. Dev中控件的js事件代码放在form标签中存在问题

    Dev中控件的js事件代码放在form标签中会获取不到(head标签中有其他js代码,未验证是否是这个问题)

  2. form标签中id和name属性的区别

    HTML元素的ID和Name属性的区别 一直认为ID和NAME是一样的,两个又可以一起出现,甚是疑惑. 今天BAIDU了一下,才发现里面大有文章.发出来研究研究: 最classical的答案:ID就像 ...

  3. Form标签+Css基础

      一.Form表单标签 <form action="" method=""></form>    表单就是用来将用户的信息提交到服务器 ...

  4. 浅谈table、form 标签

    1.<table> 标签 1.1包含的元素 <caption></caption>:表头信息. <tr></tr> :定义一个表格行: &l ...

  5. 推荐一款好用的国产web报表软件,轻松搞定复杂报表

    随着经济全球化程度的逐步加深以及全球市场的加速整合以便最大程度地对企业资源进行整合,从而达到降低成本和提高效率的目的.Web报表由于借助于web平台,即运用了B/S模式,即"浏览器/服务器& ...

  6. 润乾V4报表放入WEBINF保护目录下如何实现

     润乾报表放入WEBINF保护目录下如何实现 WEB-INF下面的文件都是受保护的,客户为了保护项目的文件不受到非法的访问,jsp页面都放在WEB-INF下,那润乾报表放入WEB-INF保护目录下 ...

  7. tomcat下部署润乾报表

    因为项目需要,需要在项目中配置润乾报表,之前一直是用的jboss服务器,此处调整为tomcat时出错,然后各种找错,找答案,最后终于好了,然后总结一下. 首先在apache-tomcat-6.0.43 ...

  8. 今天我碰到了由于web.xml文件表头信息导致润乾报表启动失败的问题,解决方案如下

    下面是从2.3,2.4.2.5 3.0集中版本的web.xml头信息的细节,当发现系统启动不报错但是该生成的功能没有正常生成,特别是在这次配置润乾报表的时候发现用2.4版本的时候,在web.xml中配 ...

  9. 润乾报表新功能–导出excel支持锁定表头

     在以往的报表设计中,锁定表头是会经常被用到的一个功能,这个功能不仅能使浏览的页面更加直观,信息对应的更加准确,而且也提高了报表的美观程度.但是,很多客户在将这样的报表导出excel时发现exce ...

随机推荐

  1. IQKeyboardManager 问题锦集

    Keep UINavigationBar at the top (Don't scroll with keyboard) (#21, #24) If you don't want to hide th ...

  2. oracle 转 mysql 最新有效法

    关键字:Oracle 转 MySQL . Oracle TO MySQL 没事试用了一下Navicat家族的新产品Navicat Premium,他集 Oracle.MySQL和PostgreSQL管 ...

  3. 剑指offer四十九之把字符串转换成整数

    一.题目 将一个字符串转换成一个整数,要求不能使用字符串转换整数的库函数. 数值为0或者字符串不是一个合法的数值则返回0 二.思路 详见代码. 三.代码 public class Solution { ...

  4. Ejb3 + Jboss8 出现Session id hasn't been set for stateful component

    Ejb 3 + JBoss 8  在使用客户端远程访问有状态的Ejb对象时,出现ERROR: Session id hasn't been set for stateful component 出现该 ...

  5. Vue中子组件调用父组件的方法

    Vue中子组件调用父组件的方法 相关Html: <!DOCTYPE html> <html lang="en"> <head> <meta ...

  6. Hadoop HDFS概念学习系列之HDFS升级和回滚机制(十二)

    不多说,直接上干货! HDFS升级和回滚机制 作为一个大型的分布式系统,Hadoop内部实现了一套升级机制,当在一个集群上升级Hadoop时,像其他的软件升级一样,可能会有新的bug或一些会影响现有应 ...

  7. Android 7.0 FileProvider 使用说明

    FileProvider FileProvider 这个组件在Android 22.0.0 (也就是 Android 5.0 ) 版本下加入进Android系统,该组件是ContentProvider ...

  8. springcloud 熔断处理

    在springcloud微服务中,有时候一个服务挂了,我们需要友好的提示,此时我们在api网关路由上做一下过滤,进行友好的提示处理. 代码如下: import com.fasterxml.jackso ...

  9. Nodejs学习笔记(十七)—浮点运算decimal.js

    前言 开发过程中免不了有浮点运算,JavaScript浮点运算的精度问题会带来一些困扰 JavaScript 只有一种数字类型 ( Number ) JavaScript采用 IEEE 754 标准双 ...

  10. 常用算法3 - 字符串查找/模式匹配算法(BF & KMP算法)

    相信我们都有在linux下查找文本内容的经历,比如当我们使用vim查找文本文件中的某个字或者某段话时,Linux很快做出反应并给出相应结果,特别方便快捷! 那么,我们有木有想过linux是如何在浩如烟 ...