帆軟FineReport——獲取控件值和單元格值


 設置單元格的值(填報預覽):

//contentPane.setCellValue(1,0,"abc");//參數面板給單元格賦實際值,即可填報
contentPane.curLGP.setCellValue(1, 0, "abc") //報表中控件給報表中單元格賦值

獲取單元格的值(填報預覽,參數面板和報表控件都可以這樣寫):

//contentPane.getCellValue(1,0);
contentPane.curLGP.getCellValue(1, 0)
var text=contentPane.curLGP.getCellValue("D2");//獲取文本框控件所在單元格的值 
contentPane.getCellValue(sheet號,列號,行號);  //sheet號行號列號是從0開始
contentPane.curLGP.getCellValue(列號,行號);  
contentPane.curLGP.getCellValue(單元格);   

當前控件值:

this.getValue();

復模版和次模板:

this.options.form/window.parent.form

參數界面獲取參數界面控件:

var Widget = this.options.form.getWidgetByName("WidgetName"); //控件名

參數界面獲取報表中控件:

var value= contentPane.getWidgetByName("textbox").getValue(); //textbox為在報表中定義控件時命名

報表中控件獲取參數面板中控件:

var Widget = contentPane.parameterEl.getWidgetByName("id");
在這種情況下,就可以使用_g().parameterCommit();。

報表中控件獲取報表中控件:

var Widget=contentPane.getWidgetByName("tab");

在web頁面中獲取FineReport報表里面的參數界面:

document.getElementById('reportFrame').contentWindow.contentPane.parameterEl.getWidgetByName('widgetname')

工具欄按鈕獲取參數面板控件:

var temp= contentPane.parameterEl.options.form.getWidgetByName("temp").getValue();

填報屬性頁面事件獲取參數面板控件:

1
contentPane.parameterEl.getWidgetByName( "widget" ).getValue();

控件的常用方法:

Widget.setValue()該方法是給控件賦值,但是不建議在填報頁面用該方法給控件賦值,因為這是給控件賦值,並不是單元格,在填報的時候如果使用該方法賦值,每次給控件賦值完成之后,將值傳給單元格之前,會被清空,最后單元格的值還是為空,所以在填報頁面建議使用setCellValue()給控件賦值。

獲取父模板:

var form = window.parent.form; 

獲取/設置制定參數控件的值:

var pva=form.getWidgetByName("p2").getValue();
//this.options.form.getWidgetByName("p1").getValue();
form.getWidgetByName("p2").setValue(pva);

通過引入finereport.js,就可以使用FR這個對象:

<script type="text/javascript" src="/WebReport/ReportServer?op=emb&resource=finereport.js"></script>

 

doURLFlashPrint(printurl,isPopUp) //第一個參數代表路徑,第二個表示是否彈出對話框

獲取當前單元格行列號:

var row =contentPane.curLGP.getTDRow(td);   
var col =contentPane.curLGP.getTDCol(td);  

獲取工具欄的控件:

var toolbar = contentPane.toolbar;

var items = toolbar.options.items;

var customButton=items[2];//JQUERY取我們的工具欄上的按鈕.items[2]代表的是第三個。

 刷新事件(添加按鈕點擊事件):

location.reload();

自定義提交:

_g('${sessionID}').writeReport();  

自定義校驗提交:

_g('${sessionID}').verifyAndWriteReport();

自定義查詢:

_g().parameterCommit();  

點擊頁面彈出子頁面,按鈕的點擊事件:

復制代碼
FR.showIframeDialog({

url:"ReportServer?reportlet=SMES/NewAdd.cpt&op=write",

title:"title",

width:600,

height:600

})

或者

FR.showDialog("測試", 400, 400, "<div> <iframe  id='reportFrame' style='width:100%;height:350px' src='http://localhost:8075/WebReport/ReportServer?reportlet=SMES/NewEdit.cpt&op=write&PKID=${CopID}'> </iframe></div>", {collapsible:true});
復制代碼

 

子頁面刷新父頁面:

在父頁面做個按鈕,ID為btnRefresh  點擊事件為:location.reload();

在子頁面的填報成功事件里寫:

復制代碼
var top = window.parent;

var reportPane = top.contentPane;

var btn = reportPane.curLGP.write.getWidgetByName("btnRefresh");

btn.fireEvent("click");
復制代碼

 網頁框路徑:

${servletURL}?reportlet=tree2/relation.cpt&op=write 

刷新整個頁面:

location.reload();

刷新當前sheet:

this.refreshAllSheets();

刷新報表而不刷新參數面板:

contentPane.reloadCurLGPPane();

 當前單元格的值:

$$$

為空不過濾:nofilter表示不過濾,if(len($area)==0,nofilter,$area)表示參數area為空,就不過濾,若不為空則以參數值進行過濾。

 獲取當前行號並賦值給F1:

contentPane.on("cellselect", function(td) {  //獲取單元格被選中監聽事件  
  var num =contentPane.curLGP.getTDRow(td)-2;  //獲取當前行號,由於數據是從第三行開始,因此要減2  
  contentPane.curLGP.setCellValue("F1",null,num);  //給F1單元格賦值  
});

 給下拉框使用公式定義數據集:實際值:sql公式,顯示值:sql公式+"id=$$$"

在公式中使用數據集名稱:

dsname.select(colname,篩選條件1&&篩選條件2&&......) //ds中不能使用參數


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM