当前位置: 首页 > article >正文

封装轮播图 (因为基于微博小程序,语法可能有些出入,如需使用需改标签)

这是在组件中使用,基于微博语法

<template>
  <wbx-view class="" style="width: 100vw;height: 70vh;">
    <WBXswiper @change="gaibian" :vertical="false" :current="current" indicatorActiveColor="#fff" indicatorColor="#c0c0c0" :items="items"   style="width: 375px;height: 200px;border-radius: 20px;">
       <template slot="swiperItem" slot-scope="scope">
			    <wbx-image :src="scope.item.src" mode="aspectFill" style="width:375px; height: 200px;" />
       </template>
     </WBXswiper>
     <!-- //测试点击切换轮播 -->
     <wbx-view  style="margin-bottom: 30px;">
        <web-view style="width: 30px;height: 30px;border: 1px solid red;" @click="add(0)">
          <view-text>0</view-text>
        </web-view>
        <web-view style="width: 30px;height: 30px;border: 1px solid red;" @click="add(1)">
          <view-text>1</view-text>
        </web-view>
        <web-view style="width: 30px;height: 30px;border: 1px solid red;" @click="add(2)">
          <view-text>2</view-text>
        </web-view>
    </wbx-view>
	</wbx-view>
</template>

<script>
/**
 * @type WBXAppOption
 */
import WBXswiper from "../../commpents/WBXswiper/index.vue";
const pageOptions = {
  data() {
    return {
      items: [
      	{ 
      	  src: 'res/1.jpg',
          txt:222222
		},
		{ 
      	  src: 'res/1.jpg',
          txt:222222
		},
		{ 
      	  src: 'res/1.jpg',
          txt:222222
		},
	 ],
      current:0
	}
  },
  computed:{
  },
  methods: {
    gaibian(e){
      console.log(e,'change')
    },
    add(index){
      console.log(this.current)
      this.current=index
    }
  },
  components: {
    WBXswiper,
  },
  wbox: {
    onLoad() { },
    onShow() {
      // 页面显示/切入前台时触发
    },
    onHide() {
      // 页面隐藏时触发
    },
    onUnload() {
      // 页面退出时触发
    },
  },
  mounted() { },
};
export default pageOptions;
</script>

<style></style>

自己封装的swiper组件内部

<template>
    <wbx-view
      ref="objStyle"
      :style="wrapperStyle"
      @touchstart="onTouchStart"
      @touchmove="onTouchMove"
      @touchend="onTouchEnd"
    >
      <wbx-view
        class="carousel-wrapper"
        :style="carouselStyle"
        @transitionend="onTransitionEnd"
        ref="carouselWrapper"
      >
        <wbx-view :style="itemStyle"><slot name="swiperItem" :item="items[items.length - 1]"></slot></wbx-view>
        <wbx-view v-for="(item, index) in items" :key="index" :style="itemStyle"><slot name="swiperItem" :item="item"></slot></wbx-view>
        <wbx-view :style="itemStyle"><slot name="swiperItem" :item="items[0]"></slot></wbx-view>
      </wbx-view>
      <wbx-view v-if="indicatorDots" :style="{ width: containerWidth + 'px' }" style="position: absolute; bottom: 10px; display: flex; flex-direction: row; justify-content: center;">
        <wbx-view
          v-for="(item, index) in items"
          :key="index"
          :style="{ backgroundColor: index === realIndex ? indicatorActiveColor : indicatorColor }"
          style="width: 10px; height: 10px; margin: 0 5px; cursor: pointer; border-radius: 10px;"
          @click~stop="setCurrentIndex(index)"
        ></wbx-view>
      </wbx-view>
    </wbx-view>
  </template>
  
  <script>
  export default {
  /*
  items                 数据
  autoPlay              是否自动播放
  interval              自动播放间隔时间
  indicatorDots         是否显示指示点
  indicatorColor        指示点颜色
  indicatorActiveColor  当前选中的指示点颜色
  current               当前所在滑块的index
  vertical              滑动方向是否为纵向
  @change               轮播图改变时会触发 change 事件,返回当前索引值
  */
    props: {
      items: {
        type: Array,
        required: true
      },
      autoPlay: {
        type: Boolean,
        default: false
      },
      interval: {
        type: Number,
        default: 3000
      },
      indicatorDots: {
        type: Boolean,
        default: true
      },
      indicatorColor: {
        type: String,
        default: '#c0c0c0'
      },
      indicatorActiveColor: {
        type: String,
        default: '#fff'
      },
      current: {
        type: String,
        default: ''
      },
      vertical: {
        type: Boolean,
        default: false
      }
    },
    data() {
      return {
        currentIndex: 1,
        timer: null,
        startX: 0,
        startY: 0,
        offset: 0,
        isTransitioning: false,
        containerWidth: 0,
        containerHeight: 0
      };
    },
    watch: {
      current(newVal) {
        this.setCurrentIndex(newVal);
      }
    },
    computed: {
      wrapperStyle() {
        return {
          backgroundColor: "rebeccapurple",
          position: "relative",
          width: `${this.wrapperWidth}px`,
          height: `${this.wrapperHeight}px`,
        };
      },
      carouselStyle() {
        const baseTranslateValue = -this.currentIndex * (this.vertical ? this.containerHeight : this.containerWidth);
        const translateValue = baseTranslateValue + this.offset;
        console.log(this.offset,baseTranslateValue,translateValue,"999999")
        return {
          display: 'flex',
          flexDirection: this.vertical ? 'column' : 'row',
          transform: this.vertical ? `translateY(${translateValue}px)` : `translateX(${translateValue}px)`,
          transition: this.isTransitioning ? 'transform 0.3s ease-out' : 'none',
           width: !this.vertical ? `${this.wrapperWidth}px` : `${this.containerWidth}px`,
          height: this.vertical ? `${this.wrapperHeight}px` : `${this.containerWidth}px`
        };
      },
      wrapperWidth() {
        return this.containerWidth * (this.items.length + 2);
      },
      wrapperHeight() {
        return this.containerHeight * (this.items.length + 2);
      },
      itemStyle() {
        return {
          width: !this.vertical ? `${this.containerWidth}px` : `${this.containerWidth}px`,
          height: this.vertical ? `${this.containerHeight}px` : `${this.containerWidth}px`,
          flexShrink: 0
        };
      },
      realIndex() {
        return (this.currentIndex - 1 + this.items.length) % this.items.length;
      }
    },
    mounted() {
      this.updateDimensions();
      this.$nextTick(() => {
        if (this.autoPlay) {
          this.startAutoPlay();
        }
      });
    },
    beforeDestroy() {
      this.stopAutoPlay();
    },
    methods: {
      updateDimensions() {
        if (this.$refs.objStyle) {
          const objStyle =  this.$refs.objStyle.styleObject
          this.containerWidth = parseFloat(objStyle.width);
          this.containerHeight = parseFloat(objStyle.height);
        }
      },
      startAutoPlay() {
        this.timer = setInterval(() => {
          this.next();
        }, this.interval);
      },
      stopAutoPlay() {
        if (this.timer) {
          clearInterval(this.timer);
          this.timer = null;
        }
      },
      next() {
        this.offset = 0;
        this.isTransitioning = true;
        this.currentIndex += 1;
        this.$emit('change', { current: this.currentIndex });
      },
      prev() {
        this.offset = 0;
        this.isTransitioning = true;
        this.currentIndex -= 1;
        this.$emit('change', { current: this.currentIndex });
      },
      setCurrentIndex(index) {
        this.stopAutoPlay();
        this.isTransitioning = true;
        this.currentIndex = index + 1;
        if (this.autoPlay) {
          this.startAutoPlay();
        }
      },
      onTouchStart(e) {
        this.startX = e.touches[0].clientX;
        this.startY = e.touches[0].clientY;
        this.offset = 0;
        this.stopAutoPlay();
      },
      onTouchMove(e) {
        const moveX = e.touches[0].clientX;
        const moveY = e.touches[0].clientY;
        this.offset = this.vertical ? moveY - this.startY : moveX - this.startX;
      },
      onTouchEnd() {
        this.isTransitioning = true;
        if (Math.abs(this.offset) > (this.vertical ? this.containerHeight : this.containerWidth) /6) {
          if (this.offset > 0) {
            this.prev();
          } else {
            this.next();
          }
        } else {
          this.offset = 0;
        }
        if (this.autoPlay) {
          this.startAutoPlay();
        }
      },
      onTransitionEnd() {
        this.isTransitioning = false;
        this.offset = 0;
        if (this.currentIndex === this.items.length + 1) {
          this.currentIndex = 1;
        }
        if (this.currentIndex === 0) {
          this.currentIndex = this.items.length;
        }
      }
    }
  };
  </script>
  
  <style>
  </style>

http://www.kler.cn/a/329658.html

相关文章:

  • 智能学习平台系统设计与实现(代码+数据库+LW)
  • 【Unity3D】利用Hinge Joint 2D组件制作绳索效果
  • 学习记录1
  • python实现pdf转word和excel
  • R语言绘图
  • OpenAI推出首个AI Agent!日常事项自动化处理!
  • [Day 77] 區塊鏈與人工智能的聯動應用:理論、技術與實踐
  • java往word中添加水印,往excel中添加图片
  • kafka 换盘重平衡副本 操作流程
  • Java面试——操作系统篇
  • 【PCB工艺】表面贴装技术中常见错误
  • 【高效管理集合】并查集的实现与应用
  • springboot3通过HttpRequest请求soap
  • 躺平成长:微信小程序运营日记第二天
  • C0005.Clion中移动ui文件到新目录后,报错问题的解决
  • 『功能项目』宠物的召唤跟随【79】
  • 有关Python时间戳的计算
  • OpenAI全新多模态内容审核模型上线:基于 GPT-4o,可检测文本和图像
  • lstm实践
  • 如何在 Windows 10 上恢复未保存/删除的 Word 文档
  • C++ 学习,标准库
  • 结构光编解码—正反格雷码解码代码
  • SQL_create_view
  • VR、AR、MR、XR 领域最新科研资讯获取指南
  • CSS链接
  • 查找与排序-快速排序