mustache.jsを使用して複数のカウンターを作成し、ローカルストレージを使用してデータを記憶するカウンターアプリに取り組んでいます。'+'ボタンをクリックして新しいカウンターを追加し、追加ボタンを押してカウンターを増やします。
私はいくつかの問題を抱えています:-追加し、複数のカウンターがある場合、それらはすべて増加します。-閉じるボタンをクリックすると、カウンターも増えます。
入力フィールドからタイトルを入力して、ローカルストレージに記憶させることもできますか?
どんな助けでも大歓迎です。解決策があれば説明していただけますか?
ここでフィドルを参照してください:http://jsfiddle.net/techydude/MSnuE/
Javascript:
$(function() {
var doc = $(document),
CounterContainer = $("#CounterContainer"),
//Container for all Counters
container = $(".counter"),
//Individual Conter Counters
counter = $(".valueCount"),
addBtn = $(".add"),
valueCount = $(".valueCount").html(),
addCounter = $("#create-counter"),
counterTemplate = Mustache.compile($("#counter-template").html());
if (localStorage.counterSave) {
CounterContainer.html(localStorage.counterSave);
}
function save() {
localStorage.counterSave = CounterContainer.html();
}
addCounter.submit(function(e) {
// prevent page from refresing
e.preventDefault();
var value = 5;
makeCounter(value);
save();
});
function makeCounter(value) {
$(counterTemplate({
txt: value
})).appendTo(CounterContainer);
}
CounterContainer.on("click", addBtn, function(valueCount) {
var EachContainer = $("div.valueCount"),
EachContainerValue = $("div.valueCount").html();
EachContainer.html(++EachContainerValue);
console.log("test");
save();
});
doc.on("click", "button.removeCounter", function() {
$(this).parent().remove();
save();
});
});