5

当我添加一条新记录(在默认可视区域之外)并更新数据表时,我有一个包含 100 多条记录的可滚动数据表,数据表从记录 0 加载,而我需要在前一个位置的数据表视图。

我的数据表代码

<p:dataTable id="DataTable" value="#{dtMB.selectDataModel}" var="test" scrollable="TRUE" scrollHeight="500" styleClass="day-column2" selectionMode="single" >
 <ui:insert name="TableInsert" >
        <ui:include src="test.xhtml" />
 </ui:insert>   
</p:dataTable>

更新数据表的命令按钮(在对话框内)

<p:commandButton id="saveNew"  value="Save" type="submit" process="@parent" onsuccess="addNew.hide()"  action="#{dtMB.addNew()}"   update=":FORM:usrMsg :FORM:TABView:DataTable"/>

目前我需要滚动回第 n 条记录以查看添加了什么或进行任何更新等。primeface 数据表中是否有任何选项,或者我需要为此编写一个 javascript。

4

1 回答 1

7

我使用以下帖子完成了上述操作

primeface 数据表滚动条位置

数据表滚动

我的代码

脚本

function saveScrollPos() {
var scrollPos = jQuery('#receptionFORM\\:receptionTV\\:scheduleDataTable .ui-datatable-scrollable-body').prop('scrollTop');
document.getElementById('receptionFORM:scrollPos').value = scrollPos;
}

function autoScroll() {
var scrollPos = document.getElementById('receptionFORM:scrollPos').value;
jQuery('#receptionFORM\\:receptionTV\\:scheduleDataTable .ui-datatable-scrollable-body').animate({scrollTop:scrollPos}, scrollPos); 
}

隐藏输入

<h:inputHidden id="scrollPos" />

在数据表行选择的 Ajax 事件中

onstart="saveScrollPos()"

保存记录时命令按钮中的以下代码

oncomplete="autoScroll()"
于 2012-10-02T23:53:44.937 回答