【问题标题】:Local Storage form in HTML5HTML5 中的本地存储表单
【发布时间】:2012-11-06 08:02:36
【问题描述】:

我正在尝试将数字存储到具有购物车类型的类型网站的本地存储中...我找到了存储文本/电子邮件有效的示例,但是当我尝试存储为数字而不是文本或更改表单时命名它似乎不起作用。

这是我在网站上制作的用于捕获数据的表单,然后是应该填写来自另一个会话的已保存数据、捕获数据和(当前在提交时重置)数据的 javascript。

<form id="localStorageCart" method="post" action="">
  <label>Rooster:</label>
  <input type="number" name="roosterQ" id="roosterQ" class="stored" min="0" max="99" step="1" value ="0" /><br>


  <label>Cow:</label>
  <input type="number" name="cowQ" id="cowQ" class="stored" min="0" max="99" step="1" value ="0" /><br>


  <label>Cat:</label>
  <input type="number" name="catQ" id="catQ" class="stored" min="0" max="99" step="1" value ="0" /><br>


  <label>Sheep:</label>
  <input type="number" name="sheepQ" id="sheepQ" class="stored" min="0" max="99" step="1" value ="0" /><br>


  <label>Dumpster:</label>
  <input type="number" name="dumpsterQ" id="dumpsterQ" class="stored" min="0" max="99" step="1" value ="0" /><br>


  <label>Dog:</label>
  <input type="number" name="dogQ" id="dogQ" class="stored" min="0" max="99" step="1" value ="0" /><br>


  <label>Horse:</label>
  <input type="number" name="horseQ" id="horseQ" class="stored" min="0" max="99" step="1" value ="0" /><br>



    <input type="submit" class="submitOrder" value="Submit" />
</form><br>
<br>

<script type="text/javascript">
$(document).ready(function () {
    function init() { /* checks for stored data and fills in... */
        if (localStorage["roosterQ"]) {
            $('#roosterQ').val(localStorage["roosterQ"]);
        }
        if (localStorage["cowQ"]) {
            $('#cowQ').val(localStorage["cowQ"]);
        }
        if (localStorage["catQ"]) {
            $('#catQ').val(localStorage["catQ"]);
        }
         if (localStorage["sheepQ"]) {
            $('#sheepQ').val(localStorage["sheepQ"]);
        }
         if (localStorage["dumpsterQ"]) {
            $('#dumpsterQ').val(localStorage["dumpsterQ"]);
        }
         if (localStorage["dogQ"]) {
            $('#dogQ').val(localStorage["dogQ"]);
        }
         if (localStorage["horseQ"]) {
            $('#horseQ').val(localStorage["horseQ"]);
        }
    }
    init();
});

$('.stored').keyup(function () { /* keyup runs when key is pressed in a form with "stored"... Write to LS */
    localStorage[$(this).attr('name')] = $(this).val();
});

$('#localStorageCart').submit(function() { /* currently resets all LS data*/
    localStorage.clear();
});
</script>

【问题讨论】:

  • 然后呢?它似乎什么也没做。我没有注意到任何形式的反馈。除了我的代码之外,我真的没有更多信息可以提供,而且它似乎没有做任何事情。这对我来说是很多新事物。

标签: javascript forms html local-storage shopping-cart


【解决方案1】:

localStorage 只能保存字符串,因此如果要存储数字,则需要输入 convert

var num = 1.5, str;

// Number to string, would be done implicitly by localStorage
str = num.toString();

// String to number
num = +str; // note nothing infront of the + sign.
// OR
// num = window.parseFloat(str,10); // or parseInt if you want integers

console.log(num, str);
// 1.5 "1.5"

或更改似乎不起作用的表单名称

你也在更新你的init 吗?为避免将来必须这样做,它应该循环遍历 .stored 而不是通过 id 单独获取每个。

【讨论】:

  • 哦,我明白了。谢谢!看起来我所要做的就是添加“.toString()”使其成为 localStorage[$(this).attr('name')] = $(this).val().toString();跨度>
  • 这不应该解决您的确切问题,因为我说完后查看了您的代码,除了在HTMLInputElements 上设置值之外,您实际上并没有对数字做任何事情。跨度>
  • 我没有更新 init 但我会这样做。循环可能更聪明,但当我第一次尝试解决问题时,我喜欢这样做。看起来刷新后数字留在页面上是我最初的意思。通常我会刷新,一切都会被设置回 0... 测试这个,因为我想接下来有一个总计页面。我在总计页面上计算了,我可以做数量 * 静态价格,所以cowQ(奶牛数量)可能是 6*$100。
【解决方案2】:

如果您仍想通过 localstorage 进行操作,您可能需要在存储变量之前检查 json.stringify

var obj = { 'a': 1, 'b': 2, 'c': 3 };
localStorage.setItem('obj', JSON.stringify(obj));

你到底打算做什么?您是否只是想保留该字段以供下次使用或重新加载页面?

如果是这样,你可能想试试这个插件,西西弗斯 http://simsalabim.github.com/sisyphus/

【讨论】:

  • 我正在尝试为每个变量存储一个数量以在另一个页面上使用。所以作为一个购物车,挑选 6 头奶牛的数量会转移到一个总页面上,总共显示 (6)*$100 = $600
  • 如果使用 PHP 编码,您为什么不能只使用 SESSION?在我看来,使用 localstorage 可能有点矫枉过正
  • 但如果您仍想通过 localstorage 进行操作,您可能需要在存储变量之前检查 json.stringify
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 2011-03-01
  • 1970-01-01
  • 1970-01-01
  • 2011-07-28
  • 2013-05-21
  • 2013-06-08
相关资源
最近更新 更多