最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

vue实现图片的跑马灯滚动

来源:动视网 责编:小采 时间:2020-11-27 19:55:48
文档

vue实现图片的跑马灯滚动

vue实现图片的跑马灯滚动:这次给大家带来vue实现图片的跑马灯滚动,vue实现图片跑马灯滚动的注意事项有哪些,下面就是实战案例,一起来看一下。父:<template> <p id="app"> <er-carousel-index :typeNumber=2 :pageNumber
推荐度:
导读vue实现图片的跑马灯滚动:这次给大家带来vue实现图片的跑马灯滚动,vue实现图片跑马灯滚动的注意事项有哪些,下面就是实战案例,一起来看一下。父:<template> <p id="app"> <er-carousel-index :typeNumber=2 :pageNumber


这次给大家带来vue实现图片的跑马灯滚动,vue实现图片跑马灯滚动的注意事项有哪些,下面就是实战案例,一起来看一下。

父:

<template>
 <p id="app">
 <er-carousel-index :typeNumber=2 :pageNumber=3 :timeSpace=2 :duration=2 :isOrNotCircle="true" url="/src/js/index.json" :isOrNotButton=false>
 <template scope="props">-----使用子组件传过来的值,封装slot
 <p class="articleList-box-photo ">
 <p class="tu imageEffectsAnimate imageEffects_Magnifier">
 <a>
 <img class="minMax" :src="props.item.img">
 </a>
 </p>
 </p>
 <p class="articleList-box-title">
 <p class="title">
 <a class="textleft">{{props.item.title}}</a>
 </p>
 </p>
 </template>
 </er-carousel-index>
 </p>
</template>
<script>
 import ErCarouselIndex from './components/carouselIndex/src/carouselIndex.vue'
 export default {
 name: 'app',
 data() {
 }
 },
 components: {
 ErCarouselIndex//一定要进行组件声明,不然不能引用子组件
 }
 }
</script>

子组件:

<template>
 <p tag="p" class="articleList articleListMod-3 er-carouseindex" name="slide-fade" id="articleList" :style="{height:imgHeight+'px'}" >
 <span id="btn1" class="er-carouseindex-left" @mousedown="imgMove('mouseLeft')" @mouseup="cancelMove('left')" v-show="isOrNotButton"></span>
 <span id="btn2" class="er-carouseindex-right" @mousedown="imgMove('mouseRight')" @mouseup="cancelMove('right')" v-show="isOrNotButton"></span>
 <p id="packageAll" class="er-carouseindex-con" @mouseover="clearAuto" @mouseout="slideAuto">
 <p class="er-carouseindex-bar" v-show="isOrNotCircle">
 <p v-for="(item,dex) in imgList" @mouseup="clearAuto" class="er-carouseindex-circle" @click="circleClick(dex)" :class="{circleSelected:dex===indexCircle}">
 </p>
 </p>
 <p id="imageAll" class="er-carouseindex-item" :style="{transform:translateX,transition:transFlag?transitionTime:''}">
 <p class="articleList-box er-carouseindex-box" v-for="(list,index) in imgLisShow" :style="{width:imgWidth+'%'}"
 style="max-height:50%;">
 <slot :item="list"></slot>
 </p>
 </p>
 </p>
 </p>
</template>
<script>
 export default
 {
 name: "ErCarouselIndex",
 data(){
 return {
 imgList: [],//请求接口数据
 imgLisShow: [],//图片滚动数据,包括左中右三种
 timer: null,//自动循环滚动时的间隔时间
 timeout:null,//长按时的图片滚动间隔时间
 index:0,//图片索引
 translateXnum:0,//图片滚动时的偏移量
 translateX:"",//生成图片偏移时的表达式
 imgWidth:"",//图片所占宽度
 timeDown:"",//鼠标刚按下时的时间
 timeup:"",//鼠标松开时的时间
 clickSpace:"",//鼠标按下松开的时间间隙
 transFlag:true,//是否匀速滚动,
 transitionTime:"",
 indexCircle:0//小圆圈滚动索引
 }
 },
 props:{
 duration:0,//图片延时滚动
 typeNumber:0, //每次滚动几张
 timeSpace:0, //图片滚动时间间隔
 url:String,//请求接口地址
 pageNumber:0,//当前页面显示几张图片
 isOrNotButton:true,//是否显示左右按钮
 isOrNotCircle:true,//是否显示小圆圈
 imgHeight:""//图片滚动显示高度
 },
 watch:{
 index:{
 handler(){
 var _this=this;
 if(Math.abs(this.index)==this.imgList.length){
 this.indexCircle=0;
 setTimeout(function(){
 _this.reset();
 },_this.duration*1000*0.98);
 }else{
 this.indexCircle=this.index;
 }
 this.calcXnum();
 }
 },
 translateXnum:{
 handler(){
 this.translateX="translateX("+this.translateXnum+"%)";
 }
 }
 },
 methods:{
 //页面初始化复赋值
 imgView:function() {
 var _this = this;
 _this.$http.get(_this.url).then(function (res) {
 _this.imgList = res.data.imgList;
 for(var i=0;i<3;i++){
 _this.imgList.forEach(function (item, index) {
 _this.imgLisShow.push(item);
 });
 }
 _this.reset();
 _this.slideAuto();
 _this.imgWidth=(100/_this.pageNumber)-1;
 _this.transitionTime="all "+_this.duration*0.98+"s linear";
 console.log(_this.transitionTime);
 });
 },
 //图片滚动方法(长按)
 imgMove:function(direct){
 var _this = this;
 _this.timeDown=new Date();//记录按下的时间
 _this.timeout = setInterval(function() {
 if(direct=="mouseLeft") {
 _this.leftMove();
 }else{
 _this.rightMove();
 }
 },300);
 },
 //鼠标送开时执行的方法
 cancelMove:function(direct){
 var _this = this;
 _this.clearAuto();
 this.timeup=new Date();//记录松开的时间
 this.clickSpace=this.timeup.getTime() - this.timeDown.getTime();
 //时间间隔小于500毫秒为点击,反之为长按
 if(this.clickSpace<500){
 for(var i=0;i<_this.typeNumber;i++){
 if(direct=="left"){
 _this.leftMove();
 }else{
 _this.rightMove();
 }
 }
 }
 if (this.timeout) {
 clearInterval(this.timeout);
 this.timeout = null;
 }
 },
 //向左移动
 leftMove:function(){
 this.index--;
 this.transFlag=true;
 },
 //向右移动
 rightMove:function(){
 this.transFlag=true;
 this.index++;
 },
 slideAuto:function () {
 var _this = this;
 _this.timer = setTimeout(function () {
 if(Math.abs(_this.index)!==_this.imgList.length){
 _this.rightMove();
 _this.slideAuto();
 }
 }, _this.timeSpace * 1000);
 },
 clearAuto:function () {
 console.log("停止");
 if (this.timer) {
 clearInterval(this.timer);
 this.timer = null;
 }
 },
 //重置
 reset:function(){
 this.index=0;
 this.transFlag=false;
 this.calcXnum();
 },
 calcXnum:function(){
 var _this=this;
 this.translateXnum=-(this.index+this.imgList.length)*(100/this.pageNumber);
 },
 //点击圆圈跳转图片
 circleClick:function(dex){
 this.index=dex;
 this.clearAuto();
 }
 },
 mounted()
 {
 this.$nextTick(function () {
 this.imgView();
 });
 }
 }
</script>

这个组件相对来说功能比较完整,用户可以通过传参来控制当前页面需要显示几张图片,图片滚动时间间隔,是否显示左右点击按钮等等,详细参数可以查看props,里面都有注释。

相信看了本文案例你已经掌握了方法,更多精彩请关注Gxl网其它相关文章!

推荐阅读:

Vue组件开发有哪些技巧

axios发送post请求springMVC无法接受参数如何处理

vue+axios在页面切换时中断请求怎么实现

文档

vue实现图片的跑马灯滚动

vue实现图片的跑马灯滚动:这次给大家带来vue实现图片的跑马灯滚动,vue实现图片跑马灯滚动的注意事项有哪些,下面就是实战案例,一起来看一下。父:<template> <p id="app"> <er-carousel-index :typeNumber=2 :pageNumber
推荐度:
标签: VUE 跑马灯 滚动
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top