전체 글
-
mitt가 귀찮아서 쓰는 VuexVue.js 2022. 8. 3. 02:25
간단한 프로젝트에서도 데이터를 주고받기가 어려워서 Vuex를 사용한다. Vuex를 사용하면, js파일에 데이터를 다 몰아넣고, 모든 컴포넌트가 데이터를 직접 꺼내쓴다. 설치해보면, npm install vuex@next --save 설치하고, 데이터저장 공간을 만들어주고 다음과 같이 입력해준다. 여기선 store.js로 만들었다. //store.js import { createStore } from 'vuex' const store = createStore({ state(){ return { } }, }) export default store 그리고 main.js에서 등록을 해주면 된다. //main.js import store from './store'; app.use(store).mount('#app..
-
멀리 있는 컴포넌트간 데이터전송 mittVue.js 2022. 8. 2. 13:21
App.vue 밑에 Container.vue 밑에 FilterBox.vue에서 고른 필터를 Container.vue로 전달해서 해당 필터를 Container에 있는 이미지에 씌울 수 있는데, 필터도 중요한 data이기에 App.vue로 전달해서 data를 보관하려한다. 이럴 때 mitt라는 라이브러리를 사용한다. 먼저, yarn add mitt 설치해주고, 셋팅을 main.js에 //main.js import { createApp } from 'vue' import App from './App.vue' import mitt from 'mitt' let emitter = mitt(); let app = createApp(App); app.config.globalProperties.emitter = emit..
-
props대신 쓰는 slotVue.js 2022. 8. 1. 20:41
slot은 부모에서 자식으로 데이터를 전송하는 props를 대신하는 문법이다. 부모에서 자식으로 데이터를 전송하려면, 먼저, 자식에 구멍을 뚫고,(slot태그를 적어주기) 부모에 컴포넌트를 적을 때, 이안에 내용은 slot에 들어감 이런 식으로 컴포넌트 태그안에 내용이 slot태그에 들어가게 할 수 있다. //부모 {{데이터}} //자식 이런 식으로 사용하면 데이터가 슬롯자리에 들어가게 된다. slot은 속성엔 사용할 수 없어서 그럴 땐, props를 사용해야 한다. 그리고 slot를 여러개 사용하려면 //부모 여기 데이터는 a자리에 감 여기 데이터는 b자리에 감 //자식 이런 식으로 사용하면 된다.
-
글 발행기능Vue.js 2022. 8. 1. 13:47
글 발행을 하려면 발행버튼을 먼저 만들어주고, 발행 publich함수를 작성해준다. publish(){ var 내게시물 = { name: "John Doe", userImage: "https://placeimg.com/200/200/people", postImage: this.이미지, likes: 20, date: "Apr 20", liked: false, content: this.발행할글, filter: "clarendon" }; this.instadata.unshift(내게시물); this.step = 0; } 기존 글과 같은 형태인 내 게시물이란 오브젝트를 만들어서, 원래 있던 data인 this.instadata에 unshift를 이용해서 맨앞으로 오게 뒷 내용을 밀어넣으면 된다. 그러면서 thi..
-
Redux toolkit (create Slice)Redux 2022. 7. 29. 13:25
createSlice를 사용하면, 코드를 더 줄일 수 있다. const addToDo = createAction("ADD"); const deleteToDo = createAction("DELETE"); //createReducer const reducer = createReducer([], { [addToDo]: (state, action) => { state.push({ text: action.payload, id: Date.now()}) }, [deleteToDo]: (state, action) => state.filter(toDo => toDo.id !== action.payload) }) 위의 코드를 const toDos = createSlice({ name: 'toDosReducer', ini..
-
Redux toolkit(create Reducer)Redux 2022. 7. 29. 12:50
createReducer은 reducer부분을 짧게 줄일 수 있다. //createAciton // const reducer = (state = [], action) => { // switch(action.type) { // case addToDo.type: // return [...state, { text: action.payload, id: Date.now()}]; // case deleteToDo.type: // return state.filter(toDo => toDo.id !== action.payload); // default: // return state; // } // }; //createReducer const reducer = createReducer([], { [addToDo]: (s..
-
Redux Toolkit(create Action)Redux 2022. 7. 29. 09:59
리덕스 툴킷은 적은량의 코드로 같은 기능을 하도록 도와주는 것이다. 먼저 설치를 해보자. npm install @reduxjs/toolkit 설치를 하고, 먼저 해볼건 createAction이다. // const ADD = "ADD"; // const DELETE = "DELETE"; // const addToDo = text => { // return { // type: ADD, // text // }; // } // const deleteToDo = id => { // return { // type: DELETE, // id: parseInt(id) // }; // } const addToDo = createAction("ADD"); const deleteToDo = createAction("DELE..
-
서버없이 업로드한 이미지다루기Vue.js 2022. 7. 29. 02:31
이미지업로드 한걸 html에 보여주려면 FileReader()을 쓰거나 URL.createObjectURL()을 사용하면 된다. + 이렇게 input태그로 type이 file이 되게 만들고, label태그를 이용해서 +를 누르면 사진을 업로드 할 수 있게 만들고, change 즉 변화가 감지되면 upload함수를 실행하게 한다. upload(e) { let file = e.target.files; let url = URL.createObjectURL(file[0]) this.step++; this.이미지 = url; } e.target.files로 업로드 된 파일들을 file변수에 담아주고, step++로 step을 1더해 탭을 이용한 페이지변경을 해준다. 그리고, url이라는 변수에 URL.create..