使用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 相关文章推荐
HTML+CSS3 模仿Windows7 桌面效果
Jun 17 HTML / CSS
用CSS禁用输入法(CSS3 UI规范)实例解析
Dec 04 HTML / CSS
用css3实现转换过渡和动画效果
Mar 13 HTML / CSS
CSS3中的弹性布局em运用入门详解 1em等于多少像素
Feb 08 HTML / CSS
使用CSS实现弹性视频html5案例实践
Dec 26 HTML / CSS
HTML5触摸事件演化tap事件介绍
Mar 25 HTML / CSS
Html5元素及基本语法详解
Aug 02 HTML / CSS
HTML5之消息通知的使用(Web Notification)
Oct 30 HTML / CSS
HTML5自定义属性的问题分析
Aug 16 HTML / CSS
在html页面中取得session中的值的方法
Aug 11 HTML / CSS
AmazeUI 网格的实现示例
Aug 13 HTML / CSS
HTML5来实现本地文件读取和写入的实现方法
May 25 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
教你如何开启shopnc b2b2c 伪静态
2014/10/21 PHP
PHP实现下载远程图片保存到本地的方法
2017/06/19 PHP
学习YUI.Ext 第四天--对话框Dialog的使用
2007/03/10 Javascript
JQuery EasyUI 对话框的使用方法
2010/10/24 Javascript
40款非常有用的 jQuery 插件推荐(系列一)
2011/12/21 Javascript
Jquery实现三层遍历删除功能代码
2013/04/23 Javascript
JavaScript实现的石头剪刀布游戏源码分享
2014/08/22 Javascript
JS实现的简洁纵向滑动菜单(滑动门)效果
2015/10/19 Javascript
jQuery获取父元素节点、子元素节点及兄弟元素节点的方法
2016/04/14 Javascript
node+experss实现爬取电影天堂爬虫
2016/11/20 Javascript
ES6 Generator函数的应用实例分析
2019/06/26 Javascript
python动态参数用法实例分析
2015/05/25 Python
wxpython中自定义事件的实现与使用方法分析
2016/07/21 Python
Python 爬虫之超链接 url中含有中文出错及解决办法
2017/08/03 Python
Python实现PS滤镜功能之波浪特效示例
2018/01/26 Python
Python通过属性手段实现只允许调用一次的示例讲解
2018/04/21 Python
Python工厂函数用法实例分析
2018/05/14 Python
python中logging模块的一些简单用法的使用
2019/02/22 Python
Python后台开发Django会话控制的实现
2019/04/15 Python
Django 创建/删除用户的示例代码
2019/07/24 Python
python实现将range()函数生成的数字存储在一个列表中
2020/04/02 Python
Python手动或自动协程操作方法解析
2020/06/22 Python
keras topN显示,自编写代码案例
2020/07/03 Python
HTML5的download属性详细介绍和使用实例
2014/04/23 HTML / CSS
丝芙兰美国官网:SEPHORA美国
2016/08/03 全球购物
激光脱毛、蓝光和护肤:Tria Beauty
2019/03/28 全球购物
海蓝之谜英国官网:La Mer英国
2020/01/15 全球购物
品管员岗位职责
2013/11/10 职场文书
日语专业个人的求职信
2013/12/03 职场文书
计算机专业职业生涯规划范文
2014/01/19 职场文书
工程建设实施方案
2014/03/14 职场文书
作文评语集锦
2014/12/25 职场文书
村党组织公开承诺书
2015/04/30 职场文书
辩护词格式
2015/05/22 职场文书
歌舞青春观后感
2015/06/10 职场文书
幼儿园教师辞职信
2019/06/21 职场文书