인프런 커뮤니티 질문&답변

토마토님의 프로필 이미지

작성한 질문수

Vue.js 중급 강좌 - 웹앱 제작으로 배워보는 Vue.js, ES6, Vuex

localStorage 관련 문의드립니다.

20.07.26 16:49 작성

·

208

1

안녕하세요!

TodoList.vue 에서 localStorage JSON.parse으로 변경 시

[Vue warn]: Error in created hook: "SyntaxError: Unexpected token 바 in JSON at position 0"

found in

---> <TodoList> at src/components/TodoList.vue

       <App> at src/App.vue

         <Root>

라는 오류가 뜨고 리스트가 나오질 않습니다 

코드를 아무리 봐도 문제가 뭔지 모르겠네요...어디가 잘못된걸까요 ㅜㅜ

TodoList.vue 코드 첨부해드립니다 ..

<template>
  <section>
    <ul>
      <li v-for="(todoItemindex) in todoItems" class="shadow" v-bind:key="todoItem">
        <i class="checkBtn fas fa-check"  v-on:click="toggleComplete"></i>
         {{todoItem}}
        <span class="removeBtn" v-on:click="removeTodo(todoItemindex)">
          <i class="removeBtn fas fa-trash-alt"></i>
        </span>
      </li>
    </ul>
  </section>
</template>

<script>
export default {
  datafunction() {
    return {
      todoItems: []
    }
  },
  methods: {
    removeTodofunction(todoItemindex) { 
      this.todoItems.splice(index, 1); // 화면에서 지우기 인덱스 하나를 지우자(하나를 콕 집어서 splice)
      localStorage.removeItem(todoItem);  //데이터베이스에서 지우기
    },
    toggleCompletefunction(){

    }
  },
  createdfunction() {
    if (localStorage.length > 0) {
      for (var i = 0i < localStorage.lengthi++) {
        if (localStorage.key(i!== 'loglevel:webpack-dev-server') { 
          this.todoItems.push(JSON.parse(localStorage.getItem(localStorage.key(i)))); //문자열로 변환
        }
      }
    }
  }
}
</script>

<style scoped>
ul {
  list-style-typenone;
  padding-left0px;
  margin-top0;
  text-alignleft;
}
li {
  displayflex;
  min-height50px;
  height50px;
  line-height50px;
  margin0.5rem 0;
  padding0 0.9rem;
  backgroundwhite;
  border-radius5px;
}
.checkBtn {
  line-height45px;
  color#62acde;
  margin-right5px;
}
.checkBtnCompleted {
  color#b3adad;
}
.textCompleted {
  text-decorationline-through;
  color#b3adad;
}
.removeBtn {
  margin-leftauto;
  color#de4343;
}
</style>

답변 1

0

장기효(캡틴판교)님의 프로필 이미지

2020. 07. 31. 11:20

안녕하세요 토마토님 제가 답변이 조금 늦었네요! :)

위에 created 쪽에서 로컬 스토리지의 데이터를 불러오는 구간에 JSON.parse를 사용하셔서 그런 것 같습니다. 저장하실 때 객체 형태로 저장하셨나요? :)