使用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 相关文章推荐
CSS Grid布局教程之浏览器开启CSS Grid Layout汇总
Dec 30 HTML / CSS
全方位了解CSS3的Regions扩展
Aug 07 HTML / CSS
使用CSS3编写类似iOS中的复选框及带开关的按钮
Apr 11 HTML / CSS
CSS3实现时间轴效果
Jul 11 HTML / CSS
HTML5图片预览实例分享
Jun 04 HTML / CSS
使用HTML5在网页中嵌入音频和视频播放的基本方法
Feb 22 HTML / CSS
关于iframe跨域使用postMessage的实现
Oct 29 HTML / CSS
Html5在手机端调用相机的方法实现
May 13 HTML / CSS
HTML5播放实现rtmp流直播
Jun 16 HTML / CSS
css实现文章分割线样式的多种方法总结
Apr 21 HTML / CSS
不要在HTML中滥用div
May 08 HTML / CSS
CSS的class与id常用的命名规则
May 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
php实现发送微信模板消息的方法
2015/03/07 PHP
PHP中empty和isset对于参数结构的判断及empty()和isset()的区别
2015/11/15 PHP
Yii2框架实现注册和登录教程
2016/09/30 PHP
PHP实现驼峰样式字符串(首字母大写)转换成下划线样式字符串的方法示例
2017/08/10 PHP
php获取微信基础接口凭证Access_token
2018/08/23 PHP
PHP面向对象程序设计之多态性的应用示例
2018/12/19 PHP
laravel-admin 后台表格筛选设置默认的查询日期方法
2019/10/03 PHP
Laravel 5.5 实现禁用用户注册示例
2019/10/24 PHP
关于javascript document.createDocumentFragment()
2009/04/04 Javascript
jquery 卷帘效果实现代码(不同方向)
2013/02/05 Javascript
利用javascript实现全部删或清空所选的操作
2014/05/27 Javascript
jQuery实现拖拽效果插件的方法
2015/03/23 Javascript
BootStrap中Datetimepicker和uploadify插件应用实例小结
2016/05/26 Javascript
Layui数据表格之获取表格中所有的数据方法
2018/08/20 Javascript
vue中动态添加class类名的方法
2018/09/05 Javascript
nodejs基础之多进程实例详解
2018/12/27 NodeJs
JavaScript 严格模式(use strict)用法实例分析
2020/03/04 Javascript
vue 动态组件用法示例小结
2020/03/06 Javascript
利用H5api实现时钟的绘制(javascript)
2020/09/13 Javascript
Python 调用VC++的动态链接库(DLL)
2008/09/06 Python
Python的subprocess模块总结
2014/11/07 Python
利用python获取Ping结果示例代码
2017/07/06 Python
在scrapy中使用phantomJS实现异步爬取的方法
2018/12/17 Python
学生信息管理系统Python面向对象版
2019/01/30 Python
django模板加载静态文件的方法步骤
2019/03/01 Python
Python request使用方法及问题总结
2020/04/26 Python
优衣库台湾官网:UNIQLO台湾
2019/02/01 全球购物
医院工作检讨书范文
2014/02/10 职场文书
新学期决心书
2014/03/11 职场文书
征婚广告词
2014/03/17 职场文书
《晚上的太阳》教学反思
2014/04/23 职场文书
政府门卫岗位职责
2014/04/29 职场文书
通知函的格式
2015/04/27 职场文书
优秀的商业计划书,让融资一步到位
2019/05/07 职场文书
go select编译期的优化处理逻辑使用场景分析
2021/06/28 Golang
Jmerte 分布式压测及分布式压测配置
2022/04/30 Java/Android