• 用CSS3来代替JS实现交互


    【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>

    【说明】

    上面包括了诸多的交互,hover的交互、checked的交互;

    对于上面的实现方法相信,早已经有很多人实现了;这里主要说说我对于这次的感悟和对于技术的憧憬,到现在工作也有近四年了,在这些年中,成长快慢自知,但相同的一点就是,很多知识都会用,也知道怎么用;可这次才真正明白,什么叫只知其意,不知其真意,为何!

    上面的交互效果,在之前我都是用css和js结合的方式实现;期间也尝试着全部使用css实现交互效果,不过却在探索的时候故步自封导致到现在才真正的实现当初的想法;

    使用CSS完全实现的好处,提高了可复用性和可维护性,对于实现相应组件提供了更好的实现方式,同时也提高了性能; 

    .list__con .input:checked+label

    如上面这种用法,我们可以使用CSS3增加的各种强大的选择器,实现更多更好的交互效果;从此离开使用JS改变DOM的悲剧,更多的倾向于CSS

    【憧憬】相信为了的CSS将会更强大,交互方面的事情都由CSS来完成;JS更多的是回归本体,最近开始研究Vuejs,从中体会到技术进步所带来的各种美好;这次体会也是在做项目中的一些体会,不仅提高了对Vue的使用,还提高了我对CSS3选择器的看法,之前一直认为CSS3选择器就是卖萌的,很多选择的方法根本就用不上;现在才知道,我们对于技术,更应该要知其真意

  • 相关阅读:
    Hadoop OutputFormat浅析
    硬盘性能
    HDFS读文件过程分析:读取文件的Block数据
    HDFS写文件过程分析
    JAVA中的编码分析
    HBase 写入优化
    HBase ttl 验证
    大数据多维分析平台的实践
    TiDB在特来电的探索
    Druid 基础使用-操作篇(Pivot、plyql)
  • 原文地址:https://www.cnblogs.com/liu-fei-fei/p/7338992.html
Copyright © 2020-2023  润新知