zoukankan      html  css  js  c++  java
  • vue 自动切换导航图

    1、做成一个组件:

    srccomponentssolution.vue

    <template>
      <div class="solutions">
        <div class="main_view">
          <h1 class="title">{{title}}</h1>
          <div class="solutions_swiper">
            <img src="../assets/imgs/direction.png" v-if="swiperIndex === 0" class="left" />
            <img
              src="../assets/imgs/direction_active2.png"
              class="left"
              v-else
              @click.stop="changeIndex('left')"
            />
            <img src="../assets/imgs/direction.png" v-if="swiperIndex === 2" class="right" />
            <img
              src="../assets/imgs/direction_active2.png"
              class="right"
              v-else
              @click.stop="changeIndex('right')"
            />
            <div class="swiper_all">
              <div class="swiper_content">
                <div class="swiper_container" id="swiper_container2">
                  <img v-for="item in all" :key="item" :src="item" />
                </div>
              </div>
            </div>
          </div>
        </div>
      </div>
    </template>
    <script>
    export default {
      props: {
        all: "",
        title: ""
      },
      data() {
        return {
          swiperIndex: 0,
            timer: ''
        };
      },
      methods: {
        changeIndex(direction) {
          //console.log('autoClick开始')
          //console.log(this.swiperIndex)
          var length = this.all.length;
          var swiper = document.getElementById("swiper_container2");
          if (direction === "left") {
            if (this.swiperIndex > 0) {
              this.swiperIndex = this.swiperIndex - 1;
           
            }
              else if (this.swiperIndex==0) {
                direction ="right"
              }
          } else {
            if (this.swiperIndex < length - 1) {
              this.swiperIndex = this.swiperIndex + 1;
    
            }
           else if (this.swiperIndex>=length-1) {
              direction ="left";
              this.swiperIndex=0;
            }
          }
          var sum = -(303 * this.swiperIndex);
          swiper.style.left = sum + "px";
        }
      },
        mounted() {
            this.timer = setInterval(this.changeIndex, 5000);
        },
        beforeDestroy() {
          clearInterval(this.timer);
        },
    };
    </script>
    <style scoped>
    .swiper_all {
      background: url("../assets/imgs/cvs_phone.png") no-repeat center center;
    }
    </style>

    2、其他vue文件中引用:

    <template>
     <swiper title="特点" :all="all"></swiper>
    </template>
    <script>
    import swiper from "../components/solution";
    export default {
      components: { swiper },
      data() {
        return {
          swiperIndex: 0,
          all: [
            require("../assets/imgs/sxbl01.png"),
            require("../assets/imgs/sxbl02.png"),
            require("../assets/imgs/sxbl03.png")
          ]
        };
      },
      created() {
        
      },
      computed: {},
      methods: {}
    };
    </script>
  • 相关阅读:
    分布式事务-第一刀
    Qt
    自描述C++部分面试题集
    读书笔记6.21
    STL vector容器 和deque容器
    C++ STL框架
    C++ 多态
    C++ 虚继承
    C++ 类的继承和派生
    C++ 类中的函数重载
  • 原文地址:https://www.cnblogs.com/25miao/p/12155791.html
Copyright © 2011-2022 走看看