使用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动画效果之animation的常用样式
Mar 09 HTML / CSS
任意一块网页内容实现“活”的背景(目前火狐浏览器专有)
May 07 HTML / CSS
CSS3绘制六边形的简单实现
Aug 25 HTML / CSS
CSS3实现头像旋转效果
Mar 13 HTML / CSS
CSS3的 fit-content实现水平居中
Sep 07 HTML / CSS
CSS3动画和HTML5新特性详解
Aug 31 HTML / CSS
详解如何通过H5(浏览器/WebView/其他)唤起本地app
Dec 11 HTML / CSS
HTML5实现应用程序缓存(Application Cache)
Jun 16 HTML / CSS
CSS3 天气图标动画效果
Apr 06 HTML / CSS
css3 实现文字闪烁效果的三种方式示例代码
Apr 25 HTML / CSS
html粘性页脚的具体使用
Jan 18 HTML / CSS
Li list-style-image 图片垂直居中实现方法
May 21 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+DBM的同学录程序(5)
2006/10/09 PHP
PHP网页游戏学习之Xnova(ogame)源码解读(八)
2014/06/23 PHP
PHP制作万年历
2015/01/07 PHP
以实例全面讲解PHP中多进程编程的相关函数的使用
2015/08/18 PHP
windows下apache搭建php开发环境
2015/08/27 PHP
PHP+Apache环境中如何隐藏Apache版本
2017/11/24 PHP
javascript HTMLEncode HTMLDecode的完整实例(兼容ie和火狐)
2009/06/02 Javascript
Css3制作变形与动画效果
2015/07/24 Javascript
Canvas放置反弹效果随机图形(实例)
2017/08/17 Javascript
JS实现点击复选框变更DIV显示状态的示例代码
2017/12/18 Javascript
JS实现快递单打印功能【推荐】
2018/06/21 Javascript
小程序组件之仿微信通讯录的实现代码
2018/09/12 Javascript
详解Next.js页面渲染的优化方案
2019/01/27 Javascript
javascript实现简易数码时钟
2020/03/30 Javascript
python列表操作使用示例分享
2014/02/21 Python
Python实现约瑟夫环问题的方法
2016/05/03 Python
Python判断某个用户对某个文件的权限
2016/10/13 Python
Python进程间通信Queue实例解析
2018/01/25 Python
python实现淘宝秒杀脚本
2020/06/23 Python
Python基于滑动平均思想实现缺失数据填充的方法
2019/02/21 Python
VSCode Python开发环境配置的详细步骤
2019/02/22 Python
wxPython实现带颜色的进度条
2019/11/19 Python
使用python模拟高斯分布例子
2019/12/09 Python
python-视频分帧&amp;多帧合成视频实例
2019/12/10 Python
Pycharm内置终端及远程SSH工具的使用教程图文详解
2020/03/19 Python
adidas澳大利亚官方网站:adidas Australia
2018/04/15 全球购物
美国领先的家庭健康检测试剂盒提供商:LetsGetChecked
2019/03/18 全球购物
亚洲颇具影响力的男性在线购物零售商:His
2019/11/24 全球购物
在SQL Server中创建数据库主要有那种方式
2013/09/10 面试题
土木工程专业个人求职信
2013/12/30 职场文书
销售内勤岗位职责
2014/04/15 职场文书
2014年个人年终总结
2015/03/09 职场文书
总经理2015中秋节致辞
2015/07/29 职场文书
2016婚礼主持词开场白
2015/11/24 职场文书
python playwright 自动等待和断言详解
2021/11/27 Python
Python sklearn分类决策树方法详解
2022/09/23 Python