当前位置:编程学习 > > 正文

vue加载html5动画(vue实现旋转木马动画)

时间:2021-10-03 01:36:09类别:编程学习

vue加载html5动画

vue实现旋转木马动画

本文实例为大家分享了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>
        <li 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>
            <li class="arrow" id="arrow">
                <a href="javascript:;" id="arrPrev" class="prev" @click='last'></a>
                <a href="javascript:;" id="arrNext" class="next" @click='next'></a>
            </li>
        </li>
    </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>
    
  • 以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持开心学习网。

    标签:
    上一篇下一篇

    猜您喜欢

    热门推荐