使用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教程:background-clip和background-origin
Oct 17 HTML / CSS
50个强大璀璨的CSS3/JS技术运用实例
Feb 27 HTML / CSS
纯CSS3实现圆角效果(含IE兼容解决方法)
May 07 HTML / CSS
实列教程 一款基于jquery和css3的响应式二级导航菜单
Nov 13 HTML / CSS
CSS3的常见transformation图形变化用法小结
May 13 HTML / CSS
移动端Web页面的CSS3 flex布局快速上手指南
May 31 HTML / CSS
通过一张图教会你CSS3倒影的实现
Sep 26 HTML / CSS
css3媒体查询中device-width和width的区别详解
Mar 27 HTML / CSS
Css3实现无缝滚动防抖
Sep 14 HTML / CSS
HTML5中的postMessage API基本使用教程
May 20 HTML / CSS
利用HTML5的新特点实现图片文件异步上传
May 29 HTML / CSS
HTML5 Canvas实现图片缩放、翻转、颜色渐变的代码示例
Feb 28 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 选项及相关信息函数库
2006/12/04 PHP
PHP 关于访问控制的和运算符优先级介绍
2013/07/08 PHP
php实现的XML操作(读取)封装类完整实例
2017/02/23 PHP
在Ubuntu 18.04上安装PHP 7.3 7.2和7.0的方法
2019/04/09 PHP
JavaScrip单线程引擎工作原理分析
2010/09/04 Javascript
基于Jquery与WebMethod投票功能实现代码
2011/01/19 Javascript
动态加载外部javascript文件的函数代码分享
2011/07/28 Javascript
函数式 JavaScript(一)简介
2014/07/07 Javascript
JS实现很酷的EMAIL地址添加功能实例
2015/02/28 Javascript
javascript中slice(),splice(),split(),substring(),substr()使用方法
2015/03/13 Javascript
简单的分页代码js实现
2016/05/17 Javascript
详解JavaScript常量定义
2017/01/03 Javascript
jQuery实现鼠标悬停3d菜单展开动画效果
2017/01/19 Javascript
简单实现js无缝滚动效果
2017/02/05 Javascript
基于vue2.0+vuex的日期选择组件功能实现
2017/03/13 Javascript
JS简单实现数组去重的方法示例
2017/03/27 Javascript
vue.js中Vue-router 2.0基础实践教程
2017/05/08 Javascript
Angular 组件之间的交互的示例代码
2018/03/24 Javascript
Node.js中,在cmd界面,进入退出Node.js运行环境的方法
2018/05/12 Javascript
Node.js Domain 模块实例详解
2020/03/18 Javascript
vue 计算属性和侦听器的使用小结
2021/01/25 Vue.js
python中使用sys模板和logging模块获取行号和函数名的方法
2014/04/15 Python
Python下的subprocess模块的入门指引
2015/04/16 Python
python写入xml文件的方法
2015/05/08 Python
Pycharm 实现下一个文件引用另外一个文件的方法
2019/01/17 Python
Django Sitemap 站点地图的实现方法
2019/04/29 Python
Django使用rest_framework写出API
2020/05/21 Python
使用Keras训练好的.h5模型来测试一个实例
2020/07/06 Python
使用python实现下载我们想听的歌曲,速度超快
2020/07/09 Python
python+selenium 简易地疫情信息自动打卡签到功能的实现代码
2020/08/22 Python
Python类绑定方法及非绑定方法实例解析
2020/10/09 Python
python实现计算器简易版
2020/12/17 Python
美国内衣第一品牌:Hanes(恒适)
2016/07/29 全球购物
组织关系转移介绍信
2014/01/16 职场文书
如何书写公司员工保密协议?
2019/06/27 职场文书
在项目中使用redis做缓存的一些思路
2021/09/14 Redis