【CSS动画】饿了么加入购物车抛物线动画实现

html-css018

【CSS动画】饿了么加入购物车抛物线动画实现,第1张

每次吃饭点外卖的时候(暴露了自己是个死肥宅,手动滑稽),或者在淘宝购物的时候,将商品加入购物车时会有一个很炫酷的动画,如下图饿了么点餐动画:

所以百度了一下前端使用css实现这个效果,然后就自己就照葫芦画瓢的写了一个小小的demo,完全当作学习了一把。

在界面上,我是参考了图片上的界面,写的css,然后在美团上面扒的数据。完成后的界面如下图:

开始想着只是做一个简单的实现效果,界面上只有div框,按钮什么的这些,反正想着很丑的界面,但是自己看到饿了么这么好看的界面,自己就忍不住模仿着写了一下下。

主要用到的是移动端适配方案:flexible.js + rem的方案

首先获取到页面上所有按钮,然后给按钮添加点击事件,获取到点击当前按钮的位置坐标信息

方案一:使用定位+transition的方式实现

方案二:使用transform + transition的方式实现

其实还可以使用css的animate来实现,只不过由于需要动态计算目标位置的坐标,实现起来比较困难,所以我就没有写,如果目标位置的坐标值固定,那么可以通过animate改变top、left或者translateX、translateY的值来实现这个效果,垂直方向的动画使用贝塞尔曲线的 function-timing 。

初识CSS抛物线动画

https://github.com/HyFun/CSS-Sample-ElemeAnimate

html5+css3能用代码生成好多小图标

举个例子

<ul>

            <li class="search"><a href="#non">Search</a></li>

</ul>

<style type="text/css">

ul {

    padding:0

    margin:0

}

li {

    position:relative

    z-index:1

    overflow:hidden

    list-style:none

    padding:0

    margin:0 0 .24em

}

li a:link, 

li a:visited {

    display:block

    border:0

    padding-left:25px

    color:#c55500

}

li a:hover, 

li a:focus, 

li a:active {

    color:#730800

    background:transparent

}

li:before, 

li:after,

li a:before, 

li a:after {

    content:""

    position:absolute

    top:50%

    left:0

}

li a:before, 

li a:after {

    margin:-8px 0 0

    background:#c55500

}

li a:hover:before, 

li a:focus:before, 

li a:active:before {

    background:#730800

}

.search a:before {

    width:6px

    height:6px

    border:3px solid #c55500

    background:transparent

    /* css3 */

    -webkit-border-radius:12px

    -moz-border-radius:12px

    border-radius:12px

}

.search a:after {

    left:10px

    width:3px

    height:7px

    margin-top:0

    /* css3 */

    -webkit-transform:rotate(-45deg)

    -moz-transform:rotate(-45deg)

    -o-transform:rotate(-45deg)

    transform:rotate(-45deg)

}

.search a:hover:before, 

.search a:focus:before, 

.search a:active:before {

    border-color:#730800

    background:transparent

}

.search a:hover:after, 

.search a:focus:after, 

.search a:active:after {

    background:#730800

}

</style>