我们有一个REST服务和Dojo DataGrid,它不会在初始加载时保存对可编辑列的更改 - 这意味着XPage会加载和更改。保存更改的唯一方法是在调用REST服务的close()或revert()方法之后,然后调用save()方法。 REST服务指向同一服务器上的另一个数据库,并使用keys属性:
<xe:restService id="rsVictims" pathInfo="rsVictimsData">
<xe:this.service>
<xe:viewItemFileService defaultColumns="true"
viewName="InvoiceGridVictims" contentType="application/json"
databaseName="voca\vocadatastore.nsf" keys="k28ts71zrjsw">
</xe:viewItemFileService>
</xe:this.service>
</xe:restService>
这是DataGrid:
<xe:djxDataGrid id="djxDataGrid1" storeComponentId="rsVictims"
autoHeight="90">
<xe:djxDataGridColumn id="djxDataGridColumn1"
label="Target" width="35px" field="victimTarget">
</xe:djxDataGridColumn>
<xe:djxDataGridColumn id="djxDataGridColumn2"
label="Oct" width="35px" field="month_10" editable="true">
</xe:djxDataGridColumn>
</xe:djxDataGrid>
它像这样流动:
使用REST服务和DataGrid打开XPage
对可编辑列进行更改 单击调用此代码的“保存”按钮(代码从Brad Balassaitis' demo复制,06自定义控件):
<xp:button value="Save Changes" id="victimsSaveButton">
<xp:eventHandler event="onclick" submit="false">
<xp:this.script><![CDATA[// Save the changes...
editedRows = [-1];
var args = {onError: function() {alert('error!');}};
rsVictims.save(args);
//Refresh the grid
rsVictims.close();
dijit.byId('#{id:djxDataGrid1}')._refresh();]]></xp:this.script>
</xp:eventHandler>
</xp:button>
DataGrid已关闭,刷新,但未保存更改
再次进行更改,然后单击“保存”按钮DataGrid已关闭,刷新,现在已保存更改
我注意到在打开XPage时DataGrid被加载了两次 - 我在Net选项卡中看到这是Firebug。在第一个GET上,它正确检索网格 - 响应正确,JSON格式正确,start = 0,计数= 25。
在第二个GET上,它似乎丢失了网格 - Response为空,JSON项为空,start = 25,count = 25。我已经尝试将REST服务中的start属性设置为0,但这没有做任何事情。我已经尝试将count属性设置为500,但这也没有解决它。
有趣的事实是,当视图在当前数据库中移动时 - 因此不使用REST服务上的databaseName属性 - “保存”按钮工作正常。此外,在加载DataGrid时只有一个GET,而在指向同一服务器上另一个数据库中的视图时,不是两个GET。我知道在寻找另一台服务器时存在一些问题,但这些数据库位于同一台服务器上。
我知道我发布了this topic before,但我没有得到有效的答案。我希望这能更清楚地说明我可能缺少的东西。
提前致谢!
答案 0 :(得分:0)
我目前的项目几乎完全相同。我的工作完美,所以我想我可以提供帮助。我假设你已经在之前的SO中提出了Per Lausten的建议。如果你没有,你根本无法保存。
您的代码与我的代码之间的区别在于我使用的是xe:viewJSONService而不是xe:viewFileItemService。扩展库书说如果你想要它可以更新你必须使用viewFileItem,但这不是真的。
我对viewItemFileService只有麻烦,请参阅此博客文章,了解我遇到的问题(http://notesspeak.blogspot.com/2013/07/going-with-extjs-grid-and-giving-up-on.html)我几乎完全放弃了dojo网格,但又回到了它,因为它适用于移动设备。 / p>
使用viewJSONService正常工作。而不是键属性,使用类别筛选器。对于您的类别,代码类似于:
var category:String = lineItemBean.getThisUNID();
if(category == null){
return "show nothing"
} else {
return lineItemBean.getThisUNID();
}
//prevents all records from being returned
您需要小心,因为如果类别为null,则返回所有记录,这可能是一个大问题或安全漏洞。在我的例子中,我从一个bean中提取,但你也可以在那里放一个文档引用。