使用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
CSS3 Pie工具推荐--让IE6-8支持一些优秀的CSS3特性
Sep 02 HTML / CSS
一款纯css3实现的竖形二级导航的实例教程
Dec 11 HTML / CSS
CSS3实现水平居中、垂直居中、水平垂直居中的实例代码
Feb 27 HTML / CSS
HTML5+CSS3绘制锯齿状的矩形
Mar 01 HTML / CSS
HTML5页面直接调用百度地图API获取当前位置直接导航目的地的实现代码
Mar 02 HTML / CSS
H5离线存储Manifest原理及使用
Apr 28 HTML / CSS
HTML5页面嵌入小程序没有返回按钮及返回页面空白的问题
May 28 HTML / CSS
CSS实现fullpage.js全屏滚动效果的示例代码
Mar 24 HTML / CSS
完美实现CSS垂直居中的11种方法
Mar 27 HTML / CSS
html css3不拉伸图片显示效果
Jun 07 HTML / CSS
新的CSS 伪类函数 :is() 和 :where()示例详解
Aug 05 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/06/10 PHP
jQuery的Ajax时无响应数据的解决方法
2010/05/25 Javascript
20行代码实现的一个CSS覆盖率测试脚本
2013/07/07 Javascript
Jquery对select的增、删、改、查操作
2015/02/06 Javascript
Vue.js学习笔记之 helloworld
2016/08/14 Javascript
AngularJS实现在ng-Options加上index的解决方法
2016/11/03 Javascript
使用Nodejs连接mongodb数据库的实现代码
2017/08/21 NodeJs
利用vue + koa2 + mockjs模拟数据的方法教程
2017/11/22 Javascript
微信、QQ、微博、Safari中使用js唤起App
2018/01/24 Javascript
js实现ATM机存取款功能
2020/10/27 Javascript
一个小时快速搭建微信小程序的方法步骤
2019/04/15 Javascript
element-ui tooltip修改背景颜色和箭头颜色的实现
2019/12/16 Javascript
浅析JS中NEW的实现原理及重写
2020/02/20 Javascript
React 条件渲染最佳实践小结(7种)
2020/09/27 Javascript
python对DICOM图像的读取方法详解
2017/07/17 Python
使用Python写一个贪吃蛇游戏实例代码
2017/08/21 Python
Python实现的生产者、消费者问题完整实例
2018/05/30 Python
Python中Subprocess的不同函数解析
2019/12/10 Python
Python使用sys.exc_info()方法获取异常信息
2020/07/23 Python
python中@contextmanager实例用法
2021/02/07 Python
CSS3实现任意图片lowpoly动画效果实例
2017/05/11 HTML / CSS
Lookfantastic挪威官网:英国知名美妆购物网站
2017/07/26 全球购物
River Island美国官网:英国高街时尚品牌
2018/09/04 全球购物
Linux如何为某个操作添加别名
2013/03/01 面试题
机电一体化专业应届生求职信
2013/11/27 职场文书
教育专业自荐书范文
2013/12/17 职场文书
纪检监察建议书
2014/05/19 职场文书
学生抄袭作业的检讨书
2014/10/02 职场文书
2015国庆节宣传语
2015/07/14 职场文书
高一数学教学反思
2016/02/18 职场文书
环境保护宣传标语大全!
2019/06/28 职场文书
手把手教你怎么用Python实现zip文件密码的破解
2021/05/27 Python
MongoDB修改oplog大小的四种方法
2022/04/11 MongoDB
Go web入门Go pongo2模板引擎
2022/05/20 Golang
PostgreSQL怎么创建分区表详解
2022/06/25 PostgreSQL
利用Redis实现点赞功能的示例代码
2022/06/28 Redis