请给我一些关于 GWT 中数据管理的想法。我在我的旅行门户项目中使用 Gwt,我的网页与前一页数据相关,但是当我按下浏览器的刷新按钮时,我的数据丢失了。所以请告诉我是否有任何方法可以解决这个问题。
4 回答
您可以创建一个 url 片段来编码您的数据。
字符串位置 = "ny"; History.newItem("location="+location);
将产生 www.example.com#location=ny 的 url 片段
然后如果刷新浏览器,就可以解码url片段,确定位置是ny。
对于多个参数,您可以创建一个复杂的片段并对其进行解析。
History.newItem("start="+startLocation+"&end="+endLocation); 然后网址看起来像 www.example.com#start=newyork&end=boston
GWT History 类不能用于管理页面刷新(只能后退/前进)。
单击刷新按钮向服务器发送请求,然后从服务器重新加载应用程序的状态。就这样。你必须处理它。
如果您不想丢失数据,则必须找到一种在需要时将其保存在服务器上的方法。
如果您的用户使用现代浏览器,您可以使用 HTML5 功能 localStorage 在页面刷新之间将数据存储在浏览器中。
检查此线程以获取支持的浏览器。
基本思想是在URL 片段(# 之后的 URL 部分)中存储一些状态——例如your-site.com/app#page-1
要侦听片段的更改,请使用 GWT 的History
类。当用户返回/前进或刷新页面时,片段将发生变化。
#page-1
因此,当 URL 具有vs#page-2
等时,您可以让您的应用程序执行不同的操作。
一个更通用和可扩展的解决方案类似于gwt-platform的Place架构(以及 Presenters,这对于大型应用程序也是一个好主意)