我应该使用phonegap本地存储来存储复选框字段选项

时间:2012-07-02 10:14:08

标签: jquery-mobile cordova local-storage

我开始使用jQuery mobile和Phonegap。

我有一个类别选择器,根据所选类别,我会显示属于该类别的复选框列表。 请参阅下面的1个我可能会显示的复选框组的示例。请注意,它是隐藏的,如果用户在字段“类别”中选择“位置”,我将只显示该字段。

<select name="select-choice-0" id="category" onchange="javascript:showboxes();updateresults();">
<option value="0">Select a category</option>
<option value="4">Catering</option>   
<option value="1">Locations</option>
<option value="2">Music</option>
</select>


<div id="locationthemes_box" data-role="collapsible" style="display:none;">
<h3>Themes</h3>
<div data-role="fieldcontain">
<fieldset data-role="controlgroup">
    <legend>Theme</legend>
    <input type="checkbox" name="locationthemes" id="checkbox-1" value="2" class="custom" />
    <label for="checkbox-1">Castle</label>
    <input type="checkbox" name="locationthemes" id="checkbox-2" value="3" class="custom" />
    <label for="checkbox-2">Barn</label>
    <input type="checkbox" name="locationthemes" id="checkbox-3" value="5" class="custom" />
    <label for="checkbox-3">Restaurant</label>
    <input type="checkbox" name="locationthemes" id="checkbox-4" value="8" class="custom" />
    <label for="checkbox-4">Bar</label>
</fieldset>
</div>
</div>

现在,我想要显示或隐藏更多复选框组,具体取决于所选类别。我想阻止我拥有页面中未显示的复选框的HTML。 因为那会导致不必要的带宽使用。 然后我想:也许我应该动态加载复选框组的内容,方法是在用户更改类别选择框后立即发出相关复选框和值的Web服务请求。

但这会产生大量的网络请求,而我正试图节省带宽。

所以我的想法是本地存储可能能够解决我的问题。 然后我将复选框值存储为名称/值字符串:
locationthemes = 2;城堡; 3;谷仓; 5;餐厅; 8;酒吧

我的问题:这是要走的路还是我不知道的最佳做法? 如果我的方式是建议的方式:任何使用PhoneGap本地存储的例子都非常受欢迎!

2 个答案:

答案 0 :(得分:2)

如果您使用Jquery Mobile的单页概念,其中包含一个HTML并包含其中的所有页面

<div data-role="page" id="page1">
<div data-role="page" id="page2">
<div data-role="page" id="page3">
<div data-role="page" id="page4">

然后您可以使用全局变量来存储值。

否则,您可以使用localStorage,如此处所述 http://docs.phonegap.com/en/1.8.1/cordova_storage_storage.md.html#localStorage

答案 1 :(得分:0)

我建议使用localStorage,因为Android会在必要时无情地杀死你的应用程序。一旦用户将您的应用程序置于后台一段时间,或者如果他将手机发送到睡眠状态或等待时间过长,那么应用程序可能会被杀死。在这里,您可以确保始终将应用程序的状态或重要变量存储在localStorage中,然后在重新启动应用程序时再次获取此数据(通过简单的启动检查)..