使用CSS3来代替JS实现交互


Posted in HTML / CSS onAugust 10, 2017

【CSS3和JS】

对于CSS了解的同学都知道,CSS的实现是最底层的,在实现方式和性能上都不是,JS这种提供接口的脚本可比的;从CSS3的动画和JS动画对比角度来看两者,会更清晰;而且随着前端框架的使用,页面动画会越来越多的应用CSS3

【CSS3的其他用法】

除了动画的代替,还有就是对于各种交互的实现上,也体现了CSS的强大,更多的是使用CSS3提供的选择器;

先来看个例子:可以更好的体现我这次对于CSS的深刻感悟

<style>
body{background:#f4f4f4;margin:0;}
/*list*/
.list__con{}
.list__con .box{background:#fff;position:relative;border-bottom:solid 1px #858585;overflow:hidden;}
.list__con .box:hover{background:#f4f4f4;-webkit-transition:all .6s;transition:all .6s;}
.list__con .box:hover .delete{-webkit-transition:all .6s;transition:all .6s;opacity:1;}
.list__con .input{-webkit-appearance:none;appearance:none;position:absolute;top:10px;left:12px;padding:0;border:none;margin:0;width:24px;height:24px;border:solid 2px red;border-radius:50%;box-sizing:border-box;outline:none;cursor:pointer;}
.list__con .input:checked::after{content:'';width:14px;height:14px;background:red;position:absolute;top:3px;left:3px;border-radius:50%;}
.list__con label{line-height:24px;padding:10px 0 10px 48px;display:block;-webkit-transition:all .4s;transition:all .4s;}
.list__con .input:checked+label{color:#d9d9d9;text-decoration:line-through;}
.list__con .delete{width:44px;height:44px;float:right;position:relative;cursor:pointer;opacity:0;}
.list__con .delete:hover::after{-webkit-transform:rotate(225deg);transform:rotate(225deg);}
.list__con .delete:hover::before{-webkit-transform:rotate(225deg);transform:rotate(225deg);}
.list__con .delete::after{content:'';position:absolute;width:2px;height:20px;background:red;top:12px;left:50%;margin-left:-1px;-webkit-transform:rotate(45deg);transform:rotate(45deg);border-radius:4px;-webkit-transition:all .6s;transition:all .6s;}
.list__con .delete::before{content:'';position:absolute;width:20px;height:2px;background:red;top:50%;left:12px;margin-top:-1px;-webkit-transform:rotate(45deg);transform:rotate(45deg);border-radius:4px;-webkit-transition:all .6s;transition:all .6s;}
</style>
<div class="list__con">
    <div class="box">
        <div class="delete"></div>
        <input class="input" type="checkbox" />
        <label>啥地方垃圾费</label>
    </div>
</div>

使用CSS3来代替JS实现交互

【说明】

上面包括了诸多的交互,hover的交互、checked的交互;

对于上面的实现方法相信,早已经有很多人实现了;这里主要说说我对于这次的感悟和对于技术的憧憬,到现在工作也有近四年了,在这些年中,成长快慢自知,但相同的一点就是,很多知识都会用,也知道怎么用;可这次才真正明白,什么叫只知其意,不知其真意,为何!

上面的交互效果,在之前我都是用css和js结合的方式实现;期间也尝试着全部使用css实现交互效果,不过却在探索的时候故步自封导致到现在才真正的实现当初的想法;

使用CSS完全实现的好处,提高了可复用性和可维护性,对于实现相应组件提供了更好的实现方式,同时也提高了性能;
 

.list__con .input:checked+label

如上面这种用法,我们可以使用CSS3增加的各种强大的选择器,实现更多更好的交互效果;从此离开使用JS改变DOM的悲剧,更多的倾向于CSS

HTML / CSS 相关文章推荐
css3实现背景模糊的三种方式
Mar 09 HTML / CSS
CSS3结构性伪类选择器九种写法
Apr 18 HTML / CSS
CSS3之边框多颜色Border-color属性使用示例
Oct 11 HTML / CSS
CSS3 中的@keyframes介绍
Sep 02 HTML / CSS
如何使用html5与css3完成google涂鸦动画
Dec 16 HTML / CSS
HTML5中微数据概述及在搜索引擎中的使用举例
Feb 07 HTML / CSS
HTML5 Canvas draw方法制作动画效果示例
Jul 11 HTML / CSS
html5移动端价格输入键盘的实现
Sep 16 HTML / CSS
将SVG图引入到HTML页面的实现
Sep 20 HTML / CSS
吃透移动端 1px的具体用法
Dec 16 HTML / CSS
HTML5 textarea高度自适应的两种方案
Apr 08 HTML / CSS
wordpress添加Html5的表单验证required方法小结
Aug 18 HTML / CSS
css3实现wifi信号逐渐增强效果实例
Aug 09 #HTML / CSS
CSS3 实现弹幕的示例代码
Aug 07 #HTML / CSS
浅谈CSS3特性查询(Feature Query: @supports)功能简介
Jul 31 #HTML / CSS
css3旋转木马_动力节点Java学院整理
Jul 12 #HTML / CSS
css3边框_动力节点Java学院整理
Jul 11 #HTML / CSS
使用 css3 实现圆形进度条的示例
Jul 05 #HTML / CSS
css3学习系列之移动属性详解
Jul 04 #HTML / CSS
You might like
DOM XPATH获取img src值的query
2013/09/23 PHP
Laravel 5 框架入门(一)
2015/04/09 PHP
如何使用微信公众平台开发模式实现多客服
2016/01/06 PHP
Jquery异步请求数据实例代码
2011/12/28 Javascript
js当一个变量为函数时 应该注意的一点细节小结
2011/12/29 Javascript
Jquery attr(&quot;checked&quot;) 返回checked或undefined 获取选中失效
2013/10/10 Javascript
javascript 按键事件(兼容各浏览器)
2013/12/20 Javascript
jquery实现两个图片渐变切换效果的方法
2015/06/25 Javascript
jquery mobile开发常见问题分析
2016/01/21 Javascript
Bootstrap table表格简单操作
2017/02/07 Javascript
详解cordova打包成webapp的方法
2017/10/18 Javascript
vue jsx 使用指南及vue.js 使用jsx语法的方法
2017/11/11 Javascript
一种angular的方法级的缓存注解(装饰器)
2018/03/13 Javascript
用Vue写一个分页器的示例代码
2018/04/22 Javascript
深入浅析Vue.js计算属性和侦听器
2018/05/05 Javascript
小程序指纹验证的实现代码
2018/12/04 Javascript
Python中在for循环中嵌套使用if和else语句的技巧
2016/06/20 Python
NumPy 如何生成多维数组的方法
2018/02/05 Python
浅析PyTorch中nn.Linear的使用
2019/08/18 Python
Python中关于浮点数的冷知识
2019/09/22 Python
python双向链表原理与实现方法详解
2019/12/03 Python
Python 实现递归法解决迷宫问题的示例代码
2020/01/12 Python
如何将tensorflow训练好的模型移植到Android (MNIST手写数字识别)
2020/04/22 Python
详解python日志输出使用配置文件格式
2021/02/10 Python
非凡女性奢华谦虚风格:The Modist
2017/10/28 全球购物
迪卡侬荷兰官网:Decathlon荷兰
2017/10/29 全球购物
Falconeri美国官网:由羊绒和羊毛制成的针织服装
2018/04/08 全球购物
Notino罗马尼亚网站:购买香水和化妆品
2019/07/20 全球购物
雷蛇美国官网:Razer
2020/04/03 全球购物
港湾网络笔试题
2014/04/19 面试题
小学生保护环境倡议书
2014/05/15 职场文书
领导干部民主生活会自我剖析材料范文
2014/09/20 职场文书
2015年综治维稳工作总结
2015/04/07 职场文书
2015年城乡环境综合治理工作总结
2015/07/24 职场文书
运动会广播稿50字
2015/08/19 职场文书
2016优秀员工先进事迹材料
2016/02/25 职场文书