Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
Tags
- 리액트
- typescript
- 폰트적용하기
- 타입좁히기
- returnType
- 티스토리꾸미기
- const 단언문
- CSS
- click and drag
- 누구나 자료구조와 알고리즘
- React.js
- 타입스크립트
- 성능최적화
- javascript
- Chart.js
- 2022
- 개발콘텐츠
- TSDoc
- vue.js
- utilty type
- JS console
- react
- 제네릭
- React Native
- NonNullable
- 공통컴포넌트
- reactjs
- 레이아웃쪼개기
- 반복줄이기
- 커스텀
Archives
- Today
- Total
몽땅뚝딱 개발자
[Vue.js/라이브러리] debounce 본문
◽ 설치하기
npm i vue-debounce
◽ debounce란?
연이어 함수가 호출될 때 가장 마지막이나 가장 처음의 1회만 이벤트가 발생하도록 하는 기술이다.
예를 들어, 검색어를 입력할 때 하나의 모음/자음을 입력할 때 마다 API를 호출하는 것은 비효율적이고 과도한 비용을 들게 한다. 따라서 사용자가 타이핑을 마쳤다고 생각하는 지점에서 호출해야한다. 기존에 발생한 이벤트(=사용자가 검색어를 입력할 때 발생한 이벤트)를 하나로 묶은 상태에서 가장 마지막으로 호출된 시점에서 API를 호출하면 되는 것이다.
◽ 예제
📄 main.js
import vueDebounce from "vue-debounce";
Vue.use(vueDebounce);
📄 test.vue - HTML 영역
<input
v-model="keyword"
@input="debounceInput"
placeholder="검색어를 입력하세요."
/>
📄 test.vue - <script> 영역
<script>
import { debounce } from "vue-debounce";
export default {
name: "Debounce",
data() {
return {
keyword: "",
lastedKeyword: "",
};
},
methods: {
// 화살표함수를 사용하면 작동하지 않는다. 이유는 찾아봐도 모르겠다...
// debounce([function], 시간)
debounceInput: debounce(function (e) {
// input의 입력값을 keyword에 binding 한다.
this.keyword = e.target.value;
this.lastedKeyword = this.keyword;
}, 300),
},
};
</script>
+) 추가 (2022.01.17)
화살표 함수가 작동하지 않는 이유는 아마도 이것 때문인 듯 하다.
내가 찾는 this는 그 this가 아닌 듯...
출처 및 참조
https://www.npmjs.com/package/vue-debounce
🌟 JavaScript로 Debounce 함수 구현하기
https://v3.ko.vuejs.org/api/options-data.html#computed
개인적으로 공부한 내용을 정리하는 블로그로
잘못된 개념을 게시하지않도록 주의하고 있으나 오류가 있을 수 있습니다.
'Development > Vue.js' 카테고리의 다른 글
[Vue.js] 커스텀 이벤트 작성 시 주의사항 (0) | 2022.01.04 |
---|---|
[Vue.js] 별점구현하기 (0) | 2022.01.04 |
[Vue.js/라이브러리] NProgress (0) | 2021.12.28 |
[Vue.js] vue-router의 네비게이션 가드 (0) | 2021.12.27 |
[Vue.js] .sync (0) | 2021.12.27 |
Comments