当前位置:首页 > 文章 > 正文内容

前端开发日常——CSS动画无限轮播

廖万里3年前 (2022-10-27)文章20627

近来没有什么值得写的东西,空闲的时候帮前端的同学做了些大屏上的展示模块,就放在这里写写吧,手把手“需求->设计-> 实现”,受众偏新手向。

  前端开发日常——CSS动画无限轮播

  为了直观便于理解, 直接把结果贴在上面。

  如上所示,基本需求比较简单明了, “分页显示供应商、供应占比列表,自动轮播”。

  一、需求评审

  该有的环节还是要有,尽管需求简单,评审不能省略,无论形式。开发的同学千万不要真的相信需求就这么简单,否则南辕北辙,出力不讨好,那必定是日常-_-||。

  于是有丰富填坑经验的开发同学,对于这个简单的模块需求,可能会提出如下的一些问题

  1. 如果只有一页,要不要轮播?

  2.每页的轮播间隔频率是多少?

  3.如果列表没有数据,如何显示这个模块?

  4.数据的刷新时机?是翻页刷新,轮播一圈刷新,还是其他?

  5.这个绿色的比值是什么含义? 是不是还有红色?

  6.百分比的小数位?

  7.如果接口异常比如网络不通,如何表示这种异常?

  8.供应商的名字会不会有500字那么长? 放不下如何布局?

  ……等等

  以上任何一个未明确的需求,都可能成为你编码完成后的一个bug或优化建议。 o(* ̄︶ ̄*)o。

  二、设计评审  

  关于上面待确认的每一个问题,我们伟大的产品经理都一一耐心的给出了“令人信服的”回答后。还是不能马上开始编码。下面我们需要进行一些技术方案的设计讨论,由技术leader把关。例如:

  1. 数据流,这个列表的数据,是从数据库中的哪几个表取出的? 确认下查询逻辑。

  2.接口设计,是一次返回前端所有数据,还是支持分页查询。

  3.性能考虑,查询频率是不是较高,并发是不是大,缺不缺索引,要不要上缓存?

  4.轮播如何实现? 有没有已经集成的轮播控件,是否满足要求,还是需要自己写一个。

  5.如何进行模块化开发,作为一个模块集成嵌入到整体页面中。

  ……等等

  明确了以上的问题后,作为前端同学的我,是不是可以开始撸代码了?

   

  三、想清楚再写

  说到这里,

  一类同学已经开始着手编码了, 第一个想到需要写的方法可能是,ajax 去后台请求数据列表的接口。

  另一类同学,可能仍在构思,如何组织代码,提炼主要的数据结构和功能方法。

  这里我们显然应该向“另外一类”同学学习。想清楚再写,是一个毫无疑问的好习惯

  技术预研

  实现一个功能,首先要扫除其中的未知技术点,扫除了所有未知之后,才能够优化的组织实现方案

  上面的需求对于我这种半吊子前端来说,比较关键的两个技术问题是。

  1)用什么方案来实现滑动动画。 2)如何实现“无限滚动”。

  滑动动画——经过一番百度,总结下动画可能的实现方案,包括用JS实现或者用CSS实现。 各有优劣,js 兼容性好,控制灵活;CSS性能高,平滑流畅。因为我们的动画非常线性,简单,于是这里我们决定采用CSS动画作为动画的实现方案。

  通过简单的研究,我们已经弄清楚了, 想让一个页面元素具有一个动画效果,可以通过向他添加一个包含了动画关键真的选择器来实现,比如定义一个滑出动画类,把这个css类加到元素上,元素就可以实现滑出的动画效果。

  无限滚动——思考下滚动页面,虽然对于数据来说可能会分成很多页,但对于屏幕展示来说,实际上最多同时出现两个页面,一个是前一页,一个是当前页。在不滚动的时候只有当前页需要显示。

  顺着这个思路, 滚动这个动作对应,“当前页飞入”“前一页飞出”这两个细分动作,特别的情况是,初始显示时,是没有“前一页”的。

  那么滚动这个动作大概思路就是,

  1. 根据当前页号取得对应数据,绘制HTML页面,append到滚动区域,对其添加“飞入”动画

  2. 根据当前页号取得上一页页面元素,对其添加“飞出”动画,动画结束后将其移除, 仅显示当前页。

  四、编码实现

  终于到了编码的时间了。

  用到的 css 动画类选择器,以及关键帧 

前端开发日常——CSS动画无限轮播
.slip_in_animation{
    animation: slip_in 1s;
}.slip_out_animation{
    animation: slip_out 1s;
}/*右侧滑入*/@keyframes slip_in{
    from {transform:translateX(100%);}
    to {transform:translateX(0);}}/*右侧滑入*/@keyframes slip_out{
    from {transform:translateX(0);}
    to {transform:translateX(-100%);}}
前端开发日常——CSS动画无限轮播

  js应用于页面元素,飞入飞出, 飞出后删除,*动画在结束后并不会改变元素实际位置。所以要在动画结束前,移除元素,避免它回到之前位置,挡住当前页,发生“闪烁”

前端开发日常——CSS动画无限轮播
    //页面滑入,要显示的页面
    this.slipIn = function(pageNo){
        $("#supplierListPage_"+pageNo).addClass("slip_in_animation");
    };    //页面滑出,
    this.slipOut = function(pageNo){
        $("#supplierListPage_"+pageNo).addClass("slip_out_animation");        //移除上一页,定时比动画稍短,避免闪烁
        setTimeout(function(){
            $("#supplierListPage_"+pageNo).remove();
        },900);
    };
前端开发日常——CSS动画无限轮播

  翻页的逻辑,第一次不滚动;滚到头,把最后一页飞出,第一页飞入。

前端开发日常——CSS动画无限轮播
    this.switchNext = function(pageNo){        //附加生成新的页面
        var newPageHtml =  _this.makePageHtml(pageNo);
        $("#"+ _this.containerId).append(newPageHtml);        //多于一页的情况
        if(_this.firtshow){
            _this.firtshow= false;            //第一次换页 不需要移除之前页面。
        }else{            //前面已经有显示过的页面,需要把前面的页面滚动出去。
            var olderPage =  pageNo -1;            if(olderPage <=0){                //当前页是第一个,前一页就是最后一页
                olderPage = _this.totalPage;
            }
            _this.slipOut(olderPage);
        }
        _this.slipIn(pageNo);
    };
前端开发日常——CSS动画无限轮播

  定时滚动到下一页。如果是最后一页,重新开始第一页。

前端开发日常——CSS动画无限轮播
    this.startRolling = function(){
            _this.switchNext(_this.curPage);            //按间隔轮播
            _this.switchTimer =  setInterval(function(){                if(_this.totalPage == 1)                    return;                if(_this.curPage < _this.totalPage) {
                    _this.curPage++;
                }else{
                    _this.curPage = 1;
                }
                _this.switchNext(_this.curPage);
            },_this.switchInterval);
    };
前端开发日常——CSS动画无限轮播

写到这里,下面是完整代码,需要的可以参考。

完整的代码CSS:

前端开发日常——CSS动画无限轮播 View Code

完整JS:

前端开发日常——CSS动画无限轮播 View Code

HTML页面容器:

前端开发日常——CSS动画无限轮播 View Code

本文链接:https://www.kkkliao.cn/?id=166 转载需授权!

阅读剩余的61%

版权声明:本文由廖万里的博客发布,如需转载请注明出处。


“前端开发日常——CSS动画无限轮播” 的相关文章

“双11”,如何守住钱袋子?

“双11”,如何守住钱袋子?

“双十一”快到了,“剁手”的大斧已高高举起。购物车收藏83件,有的商品开启定价预售模式小姐姐的化妆品要不少钱呀,也不知比平时便宜多少最近几天,同事们都在热议“双十一”。 今年的“双十一”跟以往相比有新变化,比如,缩短预售时间、扩容购物车、差价一键退,不少平台还从晚上8点开始销售等。自从2009年开始...

不打游戏只看视频,骁龙和天玑竟然能拉开这么大差距?

不打游戏只看视频,骁龙和天玑竟然能拉开这么大差距?

事情是这样的。最近托尼有位同事因为之前被使用三星 4nm 工艺的骁龙 8 Gen 1 折腾怕了,所以他在把原来的旧手机卖了之后,转手换了台搭载天玑 9000 的手机。一开始他对这台手机可以说非常满意,打游戏时发热终于没那么严重了,然而时间一长,他发现手机电量貌似掉的有点快,续航并没有想象中那么顶。本...

突然崩了!一则大消息,这类股集体跳水,2000亿巨头重挫12%!千亿疫苗白马暴跌16%!信创板块又火了,恒生科技指数继续大涨

突然崩了!一则大消息,这类股集体跳水,2000亿巨头重挫12%!千亿疫苗白马暴跌16%!信创板块又火了,恒生科技指数继续大涨

中国基金报 颜颖大家好,来一起关注今天上午的市场行情和最新资讯。10月27日上午,A股重要指数全线高开:上证指数高开0.18%,深证成指涨0.23%,创业板指涨0.18%。盘面上,发电设备、贵金属、教育等板块早盘涨幅居前,医疗板块陷入调整,旅游、海运等板块跌幅居前。港股市场高调高开:恒指高开2.63...

六零后已经渐渐老了,都是独生子女家庭,以后怎样养老?

六零后已经渐渐老了,都是独生子女家庭,以后怎样养老?

我是68年的,今年54岁,我也只有一个女儿,以后怎么养老的问题,我在十年前就开始准备了,所以我的养老问题我现在一点都不担心,因为我早已经准备好了。我从上班到退休一直在银行储蓄柜工作。工作小柜台,人生大舞台,在几十年的工作中我见识了形形色色的人,也见过很多老人特别是没有退休金的老人晚年凄苦的生活。所以...

你最讨厌QQ什么?

你最讨厌QQ什么?

作为中国最早的社交软件之一, QQ承载着无数的青春。QQ最初诞生的时候,是为了方便人们之间的交流而诞生的。那时候 QQ作为我们联系的主要工具,人们之间可以进行即时通讯。我们每天都会在 QQ上和不同的人进行沟通互动。聊天的内容也十分的丰富,有的时候聊天的内容甚至超过了现在人们生活的内容。而其中最让人讨...

每晚泡脚15分钟,五年下来会有哪些变化?

每晚泡脚15分钟,五年下来会有哪些变化?

剑心学者10月07日关注我是每到秋季与冬季才开始泡脚,尽量做到每晚都泡。当然经期除外。每次用艾叶、生姜、花椒煮沸后加水泡15到20分钟左右。泡到全身发热为止。坚持两年了。我身体湿气较重,随时舌头都有齿痕,夏天怕热冬天怕冷,手脚冰凉的。现在最大改变就是晚上睡觉不穿袜子,脚也不冰凉。还是有一定的效果。当...

发表评论

访客

看不清,换一张

◎欢迎参与讨论,请在这里发表您的看法和观点。