私の小さなアプリに問題があります。ここで確認できます: http://jsfiddle.net/47bV8/
私の問題は次のとおりです。いくつかのメモを入力してから「すべてクリア」し、メモを再入力すると、コンソールは更新時に lsReturn == null を返します。
理由はわかりますが、問題を解決する方法がわかりません。
実際、私の 'var i' の値は、すべてクリアした後は 0 ではありません (値は入力した最後の音符なので、5 つの音符を入力した場合は 5 です)。そのため、音符を再入力するとタスク 6 になります。そのため、更新時に最初のループが失敗します...
localstorage.clear の後に var i = 0 を設定しようとしましたが、うまくいきません...
 jQuery(document).ready(function() {
  // Initial loading of tasks
  var i = 0;
    // clear All
  jQuery('.clear').on('click',function(e){
    e.preventDefault();
    jQuery('#tasks li').remove();
    localStorage.clear();
    jQuery(this).data('erase', true);
  });
  if(localStorage.length){  
     for( i = 0; i < localStorage.length; i++){ 
        var lsReturn = JSON.parse(localStorage.getItem('task-'+i));
        if (lsReturn == null){ // HERE IS THE PROBLEM
          var b = 0; //
        }else{
            jQuery("#tasks").append("<li id='task-"+i+"'>" + lsReturn.text  + " <a href='#'>Delete</a></li>");
           jQuery('#tasks li#task-'+i+'').css('background-color', lsReturn.color );
        }
     }
  }else{
    jQuery('header').after("<p class='error'>no messages</p>");
  }
  // ----------------- ADD A TASK ----------------------//
  jQuery("#tasks-form").submit(function() {
    if (jQuery("#task").val() != "" ) {
      jQuery('#task').attr('placeholder', "Enter a note")
      var text = jQuery("#task").val(); 
      var color = jQuery('#color').val(); 
      var allNotes = {}; 
      var note = {}; 
      note.text = text; 
      note.color = color;
      allNotes['task-'+i] = note; 
      var lsStore = JSON.stringify(allNotes['task-'+i ]);
      localStorage.setItem( "task-"+i, lsStore); 
      var lsStoreReturn = JSON.parse(localStorage.getItem("task-"+i, lsStore)); 
      jQuery("#tasks").append("<li id='task-"+i+"'>"+ lsStoreReturn.text +"<a href='#'>Delete</a></li>"); 
      jQuery('#tasks li#task-'+i+'').css('background-color', lsStoreReturn.color );
      jQuery("#task").val(""); 
      i++; 
    }else{
       jQuery('#task').attr('placeholder', "nothing in it !")
    }
    return false; 
  });
  // ----------------- REMOVE A TASK ----------------------//
  jQuery("#tasks li a").live("click", function(e) {
    e.preventDefault();
    localStorage.removeItem(jQuery(this).parent().attr("id"));
    jQuery(this).parent().remove();
    // PROBLEM solved : if I remove a task #2 in a list of  4 item for example, if i   refresh the list become 0, 1, 3, 4, 
    // so the locastorage loop doesn't find the item 2 
   for(i=0; i<localStorage.length; i++) { // SO I check my locastorage
      if(localStorage.getItem("task-"+i) == null) { // If the task 4 doesn't exist
        localStorage.setItem("task-"+i, localStorage.getItem('task-' + (i+1)));
        // I do : create  task-4 
        // and give him the value of task 5
        localStorage.removeItem('task-'+ (i+1) ); 
        // the i remove task 5
        // so the loop wiil not find task 5 and give him the value of task 6 etc..
      }
    }
  });
});