使用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学习心得分享
Aug 19 HTML / CSS
使用HTML和CSS3绘制基本卡通图案的示例分享
Nov 06 HTML / CSS
利用Bootstrap实现漂亮简洁的CSS3价格表实例源码
Mar 02 HTML / CSS
css3边框_动力节点Java学院整理
Jul 11 HTML / CSS
css3 实现圆形旋转倒计时
Feb 24 HTML / CSS
HTML5 解析规则分析
Aug 14 HTML / CSS
使用HTML5 Canvas绘制圆角矩形及相关的一些应用举例
Mar 22 HTML / CSS
html5 postMessage解决跨域、跨窗口消息传递方案
Dec 20 HTML / CSS
处理textarea中的换行和空格
Dec 12 HTML / CSS
CSS3通过var()和calc()函数实现动画特效
Mar 30 HTML / CSS
CSS font-variation 可变字体的魅力(实例详解)
Mar 03 HTML / CSS
HTML5中的DOCUMENT.VISIBILITYSTATE属性详解
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数据缓存技术
2007/02/14 PHP
php下保存远程图片到本地的办法
2010/08/08 PHP
php文件怎么打开 如何执行php文件
2011/12/21 PHP
再Docker中架设完整的WordPress站点全攻略
2015/07/29 PHP
微信支付开发动态链接Native支付
2016/07/12 PHP
PHP目录操作实例总结
2016/09/27 PHP
php与python实现的线程池多线程爬虫功能示例
2016/10/12 PHP
PHP7 新增功能
2021/03/09 PHP
JS宝典学习笔记(下)
2007/01/10 Javascript
利用javascript中的call实现继承
2007/01/22 Javascript
实例讲解JS中数组Array的操作方法
2014/05/09 Javascript
仿JQuery输写高效JSLite代码的一些技巧
2015/01/13 Javascript
JavaScript学习小结(一)——JavaScript入门基础
2015/09/02 Javascript
JS获取数组最大值、最小值及长度的方法
2015/11/24 Javascript
如何利用JS通过身份证号获取当事人的生日、年龄、性别
2016/01/22 Javascript
JavaScript入门教程之引用类型
2016/05/04 Javascript
JS获取随机数和时间转换的简单实例
2016/07/10 Javascript
JS中split()用法(将字符串按指定符号分割成数组)
2016/10/24 Javascript
jQuery Dialog 打开时自动聚焦的解决方法(两种方法)
2016/11/24 Javascript
JS实现复制功能
2017/03/01 Javascript
vue系列之requireJs中引入vue-router的方法
2018/07/18 Javascript
vue+axios+element ui 实现全局loading加载示例
2018/09/11 Javascript
vue-cli3.0 脚手架搭建项目的过程详解
2018/10/19 Javascript
Windows下支持自动更新的Electron应用脚手架的方法
2018/12/24 Javascript
vue图片上传本地预览组件使用详解
2019/02/20 Javascript
Python使用urllib模块的urlopen超时问题解决方法
2014/11/08 Python
python3.5 + PyQt5 +Eric6 实现的一个计算器代码
2017/03/11 Python
python2.x实现人民币转大写人民币
2018/06/20 Python
Python tkinter实现图片标注功能(完整代码)
2019/12/08 Python
Spring @Enable模块驱动原理及使用实例
2020/06/23 Python
Crocs美国官方网站:卡骆驰洞洞鞋
2017/08/04 全球购物
Booking.com德国:预订最好的酒店和住宿
2020/02/16 全球购物
园林设计专业毕业生求职信
2014/03/23 职场文书
中学生励志演讲稿
2014/04/26 职场文书
公司员工辞职信范文
2015/05/12 职场文书
肖申克的救赎观后感
2015/06/02 职场文书