>웹 프론트엔드 >JS 튜토리얼 >Vue의 무한 로딩 vue-infinite-loading 방법

Vue의 무한 로딩 vue-infinite-loading 방법

亚连
亚连원래의
2018-05-26 09:50:372062검색

이 글에서는 Vue에서 무한 로딩하는 vue-infinite-loading 방식을 주로 소개하고 있으니 참고용으로 올려보겠습니다.

이 기사에서는 Vue에서 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
}

템플릿 section

<infinite-loading @infinite="infiniteHandler">
  <span slot="no-more">
     我们是有底线的
  </span>
</infinite-loading>

js 부분

무한 핸들러 이벤트는 맨 아래로 스크롤할 때 자동으로 발생합니다.

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.infinite를 사용하는 경우 로드 중입니다.$ emit('$InfiniteLoading :loaded');
this.$refs.infiniteLoading.$emit('$InfiniteLoading:complete');
경고가 표시되어 매개변수를 전달하기 위해 이 메서드를 사용하도록 수정되었음을 알려줍니다. $ 상태.

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>

방향: 이 속성을 top으로 설정하면 이 구성요소는 in 위로 스크롤하면 InfinityHandler 함수를 호출합니다.

경고: 데이터가 로드된 후 스크롤 상위 요소의 scrollTop을 올바른 값으로 수동으로 설정해야 합니다. 그렇지 않으면 구성 요소가 무한 핸들러 함수를 계속해서 호출하게 됩니다.

direction="top"

<infinite-loading @infinite="infiniteHandler" direction="String">
</infinite-loading>

위 내용은 제가 모든 사람을 위해 정리한 내용입니다. 앞으로 모든 사람에게 도움이 되기를 바랍니다.

관련 기사:

jquery의 ajax는 콜백 대신 결과를 반환하는 방법, 즉 동일한 순서로 실행됩니다.

vue가 storejs에서 얻은 데이터를 처리할 때 발생하는 여러 문제 요약

webpack 로컬 개발 환경에 IP

접근이 안되는 문제에 대한 솔루션

위 내용은 Vue의 무한 로딩 vue-infinite-loading 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.