inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

[리팩토링] 할 일 목록 표시 기능

list가 안보여요...

213

June0151

작성한 질문수 1

1

<App.vue>

<template>
  <div id="app">
    <TodoHeader></TodoHeader>
    <Todoinput v-on:addTodoItem="addOneItem"></Todoinput>
    <TodoList v-bind:propsdata="todoItems" v-on:removeItem="removeOneItem"></TodoList>
    <TodoFooter></TodoFooter>
  </div>
</template>

<script>
import TodoHeader from "./components/TodoHeader.vue";
import TodoFooter from "./components/TodoFooter.vue";
import Todoinput from "./components/Todoinput.vue";
import TodoList from "./components/TodoList.vue";

export default {
  datafunction() {
    return {
      todoItems: []
    };
  },
  methods: {
    addOneItemfunction() {
      var obj = { completed: false, item: this.todoItem };
      localStorage.setItem(this.todoItem, JSON.stringify(obj));
      this.todoItems.push(obj);
    },
    removeOneItemfunction(todoItemindex) {
      localStorage.removeItem(todoItem.item);
      this.todoItems.splice(index, 1);
    }
  },  
  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)))
          );
        }
        // this.todoItems.push(
        //   JSON.parse(localStorage.getItem(localStorage.key(i)))
        // );
      }
    }
  },
  components: {
    TodoHeader: TodoHeader,
    TodoFooter: TodoFooter,
    TodoList: TodoList,
    Todoinput: Todoinput
  }
};
</script>

<style>
body {
  text-aligncenter;
  background-color#f6f6f6;
}
input {
  border-stylegroove;
  width200px;
}
button {
  border-stylegroove;
}
.shadow {
  box-shadow5px 10px 10px rgba(0000.03);
}
</style>

<TodoList.vue>

<template>
  <div>
    <ul>
      <li v-for="(todoItemindex) in propsdata" v-bind:key="todoItem.item" class="shadow">
        <button
          class="checkBtn"
          v-bind:class="{checkBtnCompleted: todoItem.completed}"
          v-on:click="toggleComplete(todoItem)"
        >V</button>
        <span v-bind:class="{textCompleted: todoItem.completed}">{{ todoItem.item }}</span>

        <!-- <span class="removeBtn" v-on:click="removeBtn(todoItem, index)">
                <i class="fas fa-trash-alt"></i> 
        </span>-->
        <button class="removeBtn" v-on:click="removeTodo(todoItemindex)">delete</button>
      </li>
    </ul>
  </div>
</template>

<script scoped>
export default {
  props: ["propsdata"],
  methods: {
    removeTodofunction(todoItemindex) {
      this.$emit("removeItem", todoItem, index);
    },
    toggleCompletefunction(todoItem) {
      todoItem.completed = !todoItem.completed;
      localStorage.removeItem(todoItem.item);
      localStorage.setItem(todoItem.item, JSON.stringify(todoItem));
    }
  }
};
</script>

<style>
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;
}
.removeBtn {
  margin-leftauto;
  color#de4343;
}
.checkBtn {
  line-height45px;
  color#62acde;
  margin-right5px;
}
.checkBtnCompleted {
  text-decorationline-through;
  color#b3adad;
}
.textCompleted {
  text-decorationline-through;
  color#b3adad;
}
</style>

dd

똑같이 따라했고, 다른 분 질문 내용도 확인하고 인덴트도 다 없앴는데도 계속 리스트가 안나오네요.... 삭제도 되고 추가도 되는데 리스트 내용만 안나와서 너무 답답해요... 

에러가 안뜨니 어디가 어떻게 잘못된건지도 잘 모르겠습니다.... 

es6 javascript vuejs vuex

답변 1

0

캡틴판교

안녕하세요 June님, 첨부해주신 코드 상으로는 문제가 없어 보이는데 혹시 아직도 해결이 안되셨을까요? :)

Chrome 개발자 모드 확장이 안됨

0

254

1

깃 권한 요청드립니다

0

118

1

vue.js 중급 리포지토리 권한 관련

0

118

1

vuex + axios 질문 있습니다!

1

198

2

깃 권한 요청드립니다!

0

161

1

강의 깃주소 문의

0

144

1

router-view에 props를 어떻게 넘길 수 있나요?

1

279

2

Vue가 인식되지 않는 현상

0

205

1

기초강좌는 어디있나요?

1

190

2

App.vue가 필요한 이유

0

192

1

getter가 정의되어 있지 않아 오류가 발생합니다.

1

253

1

뷰 라이프사이클

1

187

1

TSLint 말고 TSLint Vue 설치해도 되나요?

1

367

3

로컬 스토리지는 어디에 있나요?

1

279

1

vuex 실행시 새로고침해야지만 리스트에 나타나는 현상

1

387

2

export default 관련한 질문

0

354

2

깃허브 vue-todo 접근불가에 따른 확인요청

1

354

2

깃허브에 문제있는것 같습니다.

1

273

2

인프런 강의 재생 화면 구성 변경 문의드립니다

1

303

2

addTodo Helper 함수 적용

1

243

1

vuex 헬퍼 전역 설정

1

245

2

github 권한요청드립니다.

1

258

2

이벤트 위치에 대한 궁금증 입니다.

1

223

2

구조 차이에 대한 문의

1

344

2