>웹 프론트엔드 >JS 튜토리얼 >vue+swiper 구성 요소 개발 관련 단계

vue+swiper 구성 요소 개발 관련 단계

php中世界最好的语言
php中世界最好的语言원래의
2018-04-16 15:41:401309검색

이번에는 vue+swiper 컴포넌트 개발과 관련된 단계를 알려드리겠습니다. vue+swiper 컴포넌트 기반 개발 시 주의사항은 무엇인가요? 다음은 실제 사례입니다.

스와이프 구성 요소

<template>
  <p class="swiper-container">
    <p class="swiper-wrapper">
      <p class="swiper-slide" v-for="item in swiper"><img :src="item.room_src" alt=""></p>
      <!--<p class="swiper-slide" v-for="item in test"><img :src="item.room_src" alt=""></p>-->
    </p>
  </p>
</template>
<script>
 import Swiper from 'swiper'
 export default {
  name: 'swiper',
  data() {
   return {
    mySwiper: null,
//    test: [
//     "https://rpic.douyucdn.cn/acrpic/171024/288016_0921.jpg",
//     "https://rpic.douyucdn.cn/acrpic/171024/748396_0924.jpg",
//     "https://rpic.douyucdn.cn/acrpic/171024/453751_0922.jpg",
//     "https://rpic.douyucdn.cn/acrpic/171024/79663_0920.jpg"
//    ]
   }
  },
  props: ['swiper'], //swiper的就是test这个数据传递来的
  methods: {
   _initSwiper() {
    this.mySwiper = new Swiper('.swiper-container', {
     autoplay: 5000,//可选选项,自动滑动
    })
   },
   _updateSwiper() {
    this.$nextTick(() => {
     this.mySwiper.update(true); //swiper update的方法
    })
   },
   swiperUpdate() {
    if (this.mySwiper) { //节点存在
     this._updateSwiper(); //更新
    } else {
     this._initSwiper(); //创建
    }
   },
  },
  watch: {
   //通过props传来的数据 和 组件一加载节点就创建成功 二者不是同步,实时监听的swiper(传递的值)的变化
   swiper() {
    this.swiperUpdate();
   }
  },
  mounted() {
   this.swiperUpdate(); //页面一加载拉去数据创建节点
  }
 }
</script>
<style lang="scss" scoped>
  .swiper-container {
    width: 100%;
    height: 4rem;
    margin-top: 0.9rem;
    .swiper-wrapper {
      width: 100%;
      height: 100%;
      .swiper-slide {
        background-size: cover;
        width: 100%;
        height: 4rem;
        img {
          width: 100%;
          height: 100%;
        }
      }
    }
  }
</style>

home.vue

//html
  <swiper :swiper="roomList.slice(6,10)" ></swiper>
//js
 import swiper from 'components/swiper/swiper'
 components: {
   swiper
  },
에서 호출하는 구성 요소 메서드 문제: 단순히 _initSwiper 메서드를 호출하면 페이지를 스크롤할 수는 없지만 페이지를 임의로 수정한 다음 저장된 스와이프를 스크롤할 수 있다는 것을 알 수 있습니다. 그 이유는 초기 스와이프 노드가 성공적으로 생성되지 않았기 때문입니다. 에서 값 페이지는 스크롤되지 않습니다. swiper의 값은 레이어별로 비어 있는 상태로 인쇄될 수 있으며, 무언가를 수정할 때 값이 전달될 수 있으므로 여기서는 노드의 성공 여부를 판단하여 업데이트해야 합니다. Siwper의 방법

이 기사의 사례를 읽고 나면 방법을 마스터했다고 생각합니다. 더 흥미로운 정보를 보려면 PHP 중국어 웹사이트의 다른 관련 기사를 주목하세요!

추천 자료:

새 Sublime Text 템플릿에서 .vue를 강조 표시하세요

Node.js 환경 변수 process.env

사용에 대한 자세한 설명

위 내용은 vue+swiper 구성 요소 개발 관련 단계의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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