使用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弹性盒模型开发笔记(三)
Apr 26 HTML / CSS
浅析与CSS3的loading动画加载相关的transition优化
May 18 HTML / CSS
什么是CSS3 HSLA色彩模式?HSLA模拟渐变色条
Apr 26 HTML / CSS
HTML+CSS3模拟心的跳动实例代码
Sep 05 HTML / CSS
详解如何在css3打包后自动追加前缀插件:autoprefixer
Dec 18 HTML / CSS
详解通过变换矩阵实现canvas的缩放功能
Jan 14 HTML / CSS
使用分层画布来优化HTML5渲染的教程
May 08 HTML / CSS
如何利用input事件来监听移动端的输入
Apr 15 HTML / CSS
html5 Canvas实现图片旋转的示例
Jan 15 HTML / CSS
htnl5利用svg页面高斯模糊的方法
Jul 20 HTML / CSS
纯CSS实现一个简单步骤条的示例代码
Jul 15 HTML / CSS
HTML中link标签属性的具体用法
May 07 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
国外十大最流行的PHP框架排名
2013/07/04 PHP
CodeIgniter实现从网站抓取图片并自动下载到文件夹里的方法
2015/06/17 PHP
基于thinkPHP类的插入数据库操作功能示例
2017/01/06 PHP
php实现base64图片上传方式实例代码
2017/02/22 PHP
利用php生成验证码
2017/02/23 PHP
PHP读取Excel类文件
2017/05/15 PHP
PHP序列化的四种实现方法与横向对比
2018/11/29 PHP
jQuery实现contains方法不区分大小写的方法
2015/02/13 Javascript
javascript实现跨域的方法汇总
2015/06/25 Javascript
基于bootstrap3和jquery的分页插件
2015/07/31 Javascript
js钢琴按钮波浪式图片排列效果代码分享
2015/08/26 Javascript
详解本地Node.js服务器作为api服务器的解决办法
2017/02/28 Javascript
详解vue-cli 脚手架项目-package.json
2017/07/04 Javascript
微信小程序使用Socket的实例
2017/09/19 Javascript
angularjs实现table增加tr的方法
2018/02/27 Javascript
vue实现打印功能的两种方法
2018/09/07 Javascript
深入解析ES6中的promise
2018/11/08 Javascript
JavaScript使用ul中li标签实现删除效果
2019/04/15 Javascript
Vue.js实现tab切换效果
2019/07/24 Javascript
vue获取data数据改变前后的值方法
2019/11/07 Javascript
Vue自定义render统一项目组弹框功能
2020/06/07 Javascript
[04:16]完美世界DOTA2联赛PWL S2 集锦第一期
2020/11/23 DOTA
python网络爬虫采集联想词示例
2014/02/11 Python
python数据结构之图的实现方法
2015/07/08 Python
详解Python实现按任意键继续/退出的功能
2016/08/19 Python
Python使用numpy模块创建数组操作示例
2018/06/20 Python
python顺序的读取文件夹下名称有序的文件方法
2018/07/11 Python
Pandas之ReIndex重新索引的实现
2019/06/25 Python
Tory Burch英国官方网站:美国时尚生活品牌
2017/12/06 全球购物
车间组长岗位职责
2013/12/20 职场文书
创意活动策划书
2014/01/15 职场文书
小学三年级学生评语
2014/04/22 职场文书
文明城市标语
2014/06/16 职场文书
离婚协议书范文2015
2015/01/26 职场文书
vue实现可拖拽的dialog弹框
2021/05/13 Vue.js
OpenCV3.3+Python3.6实现图片高斯模糊
2021/05/18 Python