您当前的位置:首页 > 网站建设 > javascript
| php | asp | css | H5 | javascript | Mysql | Dreamweaver | Delphi | 网站维护 | 帝国cms | React | 考试系统 | ajax |

vue实现旋转木马动画

51自学网 2022-05-02 21:35:52
  javascript

本文实例为大家分享了vue实现旋转木马动画的具体代码,供大家参考,具体内容如下

图片数量可为任意值都能正常处理 [1-无限个]:

<!DOCTYPE html><html><head>    <title></title>    <meta charset="UTF-8">    <meta http-equiv="Access-Control-Allow-Origin" content="*">    <script src="https://cdn.jsdelivr.net/npm/vue/dist/vue.js"></script>    <style>        html,body{            font-size: 100px;        }        html,body{            width: 100%;            height: 100%;            overflow: hidden;        }        .film-box{            width:100%;            height: 100%;        }        ul{            position: relative;            width: 100%;            list-style: none;        }        ul li {            position: absolute;            top: 0;            left: 0;            z-index: 1;            width:0rem;            height: 0rem;            text-align: center;        }        ul li.film-show{            transition: all 1s;            width: 87rem;            height: 50rem;        }        ul li img {            /* width: 100%; */            height: 100%;        }        /* 左右箭头 */        .arrow {            position: absolute;            width: 100%;            top: 50%;            /* opacity: 0; */            z-index: 3;        }        .prev,.next {            position: absolute;            height: 5rem;            width: 3rem;            border-radius: 50%;            top: 50%;            margin-top: -56px;            overflow: hidden;            text-decoration: none;        }        .prev{            left: 0;            background: url("./imgs/arrow-left.png") no-repeat left top;            background-size: 100% 100%;        }        .next{            right: 0;            background: url("./imgs/arrow-right.png") no-repeat right top;            background-size: 100% 100%;        }        .filmindex{            color: #cb2e2e;            font-size: 2.4rem;            position: absolute;            bottom: 12rem;            left: 50%;            transform: translateX(-50%);        }    </style></head><body>    <div class="film-box" id='app'>        <ul id="slide">            <li v-for='(item,index) in films'                 :key='index'                v-bind:class="item.show ? 'film-show' : ''"                v-bind:style="{left:filmsHideLeft}"                 v-bind:data-index = 'index' >                 <img v-bind:src="item.image"  alt="">            </li>        </ul>        <span class="filmindex">{{ filmCurrIndex + 1 + '/' + films.length}}</span>        <div class="arrow" id="arrow">            <a href="javascript:;" id="arrPrev" class="prev" @click='last'></a>            <a href="javascript:;" id="arrNext" class="next" @click='next'></a>        </div>    </div></body><script>    var vm = new Vue({        el:'#app',        data:{            films:[],            filmsHideLeft:'0rem',//控制隐藏图片是从左上角跳出来还是从右上角跳出来            configStart:0,            filmCurrIndex:2,            config:[                {                    "transform":"scale(0.6)",                    "top": '5rem',                    "left": '-13rem',                    "zIndex": 2,                    "backgroundColor":"#98E0AD"                },      //0                {                    "transform":"scale(0.8)",                    "top": '3rem',                    "left": '13rem',                    "zIndex": 3,                    "backgroundColor":"#BAD1F0"                },     //1                {                    "transform":"scale(1)",                    "top": '2rem',                    "left": '45rem',                    "zIndex": 4,                    "backgroundColor":"#F3DFDE"                },     //2                {                    "transform":"scale(0.8)",                    "top": '3rem',                    "left": '93rem',                    "zIndex": 3,                    "backgroundColor":"#BAD1F0"                },    //3                {                    "transform":"scale(0.6)",                    "top": '5rem',                    "left":'113rem',                    "zIndex": 2,                    "backgroundColor":"#98E0AD"                },    //4            ],          lessNum:0,        },        methods:{         next(){                if (this.lessNum < 5) {                    this.nextFilmLessFive();                } else {                    this.nextFilm();                }            },            last(){                if (this.lessNum < 5) {                    this.lastFilmLessFive();                } else {                    this.lastFilm();                }            },            nextFilm(){                let self = this;                this.filmsHideLeft = '185rem';                let currShowFirst = parseInt(document.querySelectorAll('.film-show')[0].dataset.index);                // 最后一个位于正中央时按下一个不再反应                console.log(currShowFirst,self.films.length)                if (currShowFirst + 3 == self.films.length){                    return;                }                // 改变DOM的显示与隐藏                if (self.configStart == 0) {                    self.films[currShowFirst].show = false;                     if (currShowFirst + 5 <= this.films.length - 1){// 正中央显示的是倒数第二张或倒数第一张时,按下一个不需要设置哪张显示成true                        self.films[currShowFirst + 5].show = true;                    }                }else if (self.configStart == 1) {                    self.films[4].show = true;                    self.configStart = 0;                } else if(self.configStart == 2){                    self.films[3].show = true;                    self.configStart = 1;                }                                console.log(self.films)                self.$nextTick(function(){                    // 改变DOM的left,top,scale,zIndex,backgroundColor                    this.filmCurrIndex = (this.filmCurrIndex + 1 >= this.films.length - 1 ? this.films.length - 1 : this.filmCurrIndex + 1);                    self.assign();                })            },            lastFilm(){                let self = this;                this.filmsHideLeft = '0rem';                let currShowFirst = parseInt(document.querySelectorAll('.film-show')[0].dataset.index);                if (currShowFirst !== 0) {                     self.films[currShowFirst -1].show = true;                    if (currShowFirst + 4 <= this.films.length -1) {// 正中央显示的是倒数第二张或倒数第一张时,按上一个不需要设置哪张显示成false                        self.films[currShowFirst + 4].show = false;                    }                } else {                    if (self.configStart == 0) {                        self.configStart = 1;                        self.films[4].show = false;                    } else if (self.configStart == 1) {                        self.configStart = 2;                        self.films[3].show = false;                    } else {                        // 第一个位于正中央时按上一个不再反应                        return;                    }                }                console.log(self.films)                self.$nextTick(function(){                    this.filmCurrIndex = (this.filmCurrIndex - 1) < 0 ? 0 : (this.filmCurrIndex - 1);                    self.assign();                })            },           lastFilmLessFive(){                let currShowFirst = parseInt(document.querySelectorAll('.film-show')[0].dataset.index);                if (this.lessNum === 4) {                    if (!this.films[0].show) {                        this.films[0].show = true;                    } else {                        if (this.configStart === 2) return;                        if (this.configStart === 0) {                            this.configStart = 1;                        } else if (this.configStart === 1) {                            this.configStart = 2;                            this.films[3].show = false                        }                      }                                           } else if (this.lessNum === 3) {                    if (this.configStart === 1) {                        this.configStart = 2;                    } else if (this.configStart === 0) {                        this.configStart = 1;                    }                } else if (this.lessNum === 2) {                    if (this.configStart === 1) {                        this.configStart = 2;                    }                 }                this.$nextTick(function(){                    this.filmCurrIndex = (this.filmCurrIndex - 1) < 0 ? 0 : (this.filmCurrIndex - 1);                    this.assign();                })            },           nextFilmLessFive(){                let currShowFirst = parseInt(document.querySelectorAll('.film-show')[0].dataset.index);                if (this.lessNum === 4) {                    if (!this.films[0].show) return;                    if (this.configStart === 2) {                        this.configStart = 1;                        this.films[3].show = true;                    } else if (this.configStart === 1) {                        this.configStart = 0;                    } else {                        this.films[0].show = false;                    }                           } else if (this.lessNum === 3) {                    if (this.configStart === 1) {                        this.configStart = 0;                    } else if (this.configStart === 2) {                        this.configStart = 1;                    }                } else if (this.lessNum === 2) {                    if (this.configStart === 2) {                        this.configStart = 1;                    }                 }                this.$nextTick(function(){                    console.log(this.filmCurrIndex,this.films.length)                    this.filmCurrIndex = (this.filmCurrIndex + 1 >= this.films.length - 1 ? this.films.length - 1 : this.filmCurrIndex + 1);                    this.assign();                })            },            assign() {                 let self = this;                var list= document.getElementById("slide").getElementsByClassName("film-show"); //拿到所有li                for (var i = 0; i < list.length; i++){                    let json = self.config[i + this.configStart];                    for (var attr in json) {                        list[i].style[attr] = json[attr];                    }                }            }        },        mounted(){            this.films = this.films.concat([               {image:'./imgs/9.jpeg',show:true},                {image:'./imgs/1.jpg',show:true},                {image:'./imgs/2.jpg',show:true},                {image:'./imgs/3.jpg',show:true},                {image:'./imgs/4.jpg',show:true},                // {image:'./imgs/5.jpg',show:false},                // {image:'./imgs/6.jpg',show:false},                // {image:'./imgs/7.jpg',show:false},                // {image:'./imgs/8.jpg',show:false},            ]);            this.$nextTick(function(){             this.lessNum = this.films.length;                if (this.lessNum === 3) {                    this.configStart = 1;                    this.filmCurrIndex = 1;                }                if (this.lessNum === 2) {                    this.configStart = 2;                    this.filmCurrIndex = 0;                }                if (this.lessNum === 1) {                    this.configStart = 2;                    this.filmCurrIndex = 0;                }                this.assign();            })                    },        created(){            let rootWidth = document.documentElement.clientWidth || document.body.clientWidth;            let rootDom = document.querySelector('html');            rootDom.style.fontSize = rootWidth / 1920 * 10 + 'px';        }    });  // 功能增强(以上部分已经实现了旋转木马):  // 以下代码实现目标:鼠标模拟移动端的左滑右滑事件,在左滑右滑中可以切换图片    (function(){        var touchDot,flagLeft = true,flagRight = true;         var bodyDom = document.querySelector('body');        bodyDom.addEventListener('mousedown',down,false);        bodyDom.addEventListener('mousemove',move,false);        bodyDom.addEventListener('mouseup',up,false);        bodyDom.addEventListener('mouseout',up,false);        function down(event){            touchDot = event.clientX; // 获取触摸时的原点         }        function move(event){            if (touchDot !== undefined) {                var touchMove = event.clientX;                // 向左滑动                  if (touchMove - touchDot <= -40) {                    if (flagLeft) {                        vm.nextFilm();                        flagLeft = false;// 鼠标未抬起之前持续左滑最多只能左滑一张图片                        flagRight = true;// 鼠标左滑切换图片后,鼠标未抬起之前可以通过再右滑切换回到之前的图片                    } else {                        touchDot = touchMove;                    }                }                // 向右滑动                 if (touchMove - touchDot >= 40) {                    if (flagRight) {                        vm.lastFilm();                        flagRight = false; // 鼠标未抬起之前持续右滑最多只能右滑一张图片                        flagLeft = true;// 鼠标右滑切换图片后,鼠标未抬起之前可以通过再左滑切换回到之前的图片                    } else {                        touchDot = touchMove;                    }                }            }        }        function up(event){            // 鼠标抬起重置一切可以进行下一步操作;            flagRight = true;            flagLeft = true;            touchDot = undefined;        }    }())</script></html>

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持wanshiok.com。


Vue组件实现旋转木马动画
小程序通过小程序云实现微信支付功能实例
51自学网,即我要自学网,自学EXCEL、自学PS、自学CAD、自学C语言、自学css3实例,是一个通过网络自主学习工作技能的自学平台,网友喜欢的软件自学网站。
京ICP备13026421号-1