이번에는 무한 로딩 효과를 만들기 위한 vue-infinite-loading을 가져오겠습니다. 무한 로딩 효과를 만들기 위한 vue-infinite-loading의 주의 사항은 무엇인가요?
참고: vue-infinite-loading2.0은 Vue.js2.0에서만 사용할 수 있습니다. Vue.js1.0에서 사용하시려면 vue-infinite-loading1.3버전을 설치해주세요
설치방법
npm install vue-infinite-loading --save
가져오기 방법
es6 모듈 가져오기 방법
import InfiniteLoading from 'vue-infinite-loading'; export default { components: { InfiniteLoading }, };
CommonJS 모듈 가져오기 방법
const InfiniteLoading = require('vue-infinite-loading'); export default { components: { InfiniteLoading } };
다른 방법
<script src="vue-infinite-loading.js"></script>
페이지에서 적용
컴포넌트에서 직접 선언
components:{ InfiniteLoading }
템플릿 부분
<infinite-loading @infinite="infiniteHandler"> <span slot="no-more"> 我们是有底线的 </span> </infinite-loading>
js 부분
하단으로 스크롤 시 자동으로 InfinityHandler 이벤트 발생
infiniteHandler($state) { setTimeout(() => { const temp = []; for (let i = this.list.length + 1; i <= this.list.length + 20; i++) { temp.push(i); } this.list = this.list.concat(temp); $state.loaded(); $state.complete(); }, 1000); }
참고
계속
this.$refs.infiniteLoading.$emit('$InfiniteLoading:loaded');
this.$refs.infiniteLoading.$emit('$InfiniteLoading:complete');
을 사용하는 경우 경고가 표시됩니다. 수정했음을 알리기 위해 이 방법을 사용하여 $state를 매개변수로 전달합니다.
Properties
distance: 스크롤에 중요한 값입니다. 스크롤 상위 요소의 하단까지의 거리가 이 값보다 작으면 InfiniteHandler 콜백 함수가 호출됩니다.
<infinite-loading @infinite="infiniteHandler" distance="Number"> </infinite-loading>
spinner: 이 속성을 사용하면 좋아하는 스피너 중 하나를 로딩 애니메이션으로 선택할 수 있습니다.
spinner="bubbles";
1, bubble
2, 원
3, 기본값
4, 나선형
5, waveDots
<infinite-loading @infinite="infiniteHandler" spinner="String"> </infinite-loading>
direction: 이 속성을 top으로 설정하면 이 구성 요소는 다음과 같은 경우 맨 위로 스크롤됩니다. 시간이 나면 InfiniteHandler 함수를 호출하세요.
경고: 데이터가 로드된 후 스크롤 상위 요소의 scrollTop을 올바른 값으로 수동으로 설정해야 합니다. 그렇지 않으면 구성 요소가 무한 핸들러 함수를 계속해서 호출하게 됩니다.
direction="top"
<infinite-loading @infinite="infiniteHandler" direction="String"> </infinite-loading>
이 기사의 사례를 읽으신 후 방법을 마스터하셨다고 믿습니다. 더 흥미로운 정보를 보려면 PHP 중국어 웹사이트의 다른 관련 기사를 주목하세요!
추천 도서:
위 내용은 vue-infinite-loading은 무한 로딩 효과를 생성합니다.의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!