html5教程-CSS hover效果的逆向思维实现

发布时间:2018-12-18 发布网站:脚本宝典
脚本宝典收集整理的这篇文章主要介绍了html5教程-CSS hover效果的逆向思维实现脚本宝典觉得挺不错的,现在分享给大家,也给大家做个参考。
小宝典致力于为广大程序猿(媛)提供高品质的代码服务,请大家多多光顾小站,小宝典在此谢过。
 

一、一个很简单的效果实现

html5教程-CSS hover效果的逆向思维实现

很简单,鼠标移上去,出现圆角的边框线。

实现方法很多,比方说:

  1. 4状态全部呈现在Sprite上,这最好理解,只要关心background-position位置即可,一层标签就可以搞定。

    html5教程-CSS hover效果的逆向思维实现

    您可以狠狠地点击这里:牺牲背景图片大小的基本实现demo

    html5教程-CSS hover效果的逆向思维实现

  2. Sprite仅两个hover状态(见下图,下同),牺牲额外一层标签,双层标签,内层标签使用实色边框取巧覆盖(并不推荐,无法应用于其他背景色场景,不具体展示)。

    html5教程-CSS hover效果的逆向思维实现


    您可以狠狠地点击这里:内标签边框色取消覆盖demo
  3. Sprite仅两个hover状态,单层标签,clip:rect实现。您可以再次狠狠地点击这里:clip属性剪裁实现demo

    html5教程-CSS hover效果的逆向思维实现


    像素分毫不差的效果。不过clip只能应用在绝对定位元素上,因此,该方法还是有一定的限制的。
  4. Sprite仅两个hover状态,单层标签,通过控制hover前后元素的精确尺寸、背景位置、自身位置实现效果。这个方法就是本文抛砖引玉之所在。

二、抛什么砖、引什么玉

上段方法4要实现的原理也可以称为CSS hover的马桶原理。这是有典故的:

一个黑人在炎热沙漠中被活活干死了,去了天堂上帝问他有什么愿望,黑人说:“我希望下辈子变得很白,远离阳光,每天都有水喝!”上帝答应了他的要求,于是这位黑人下辈子变成了……抽水马桶。

黑人变成马桶后,兴趣变成了看美女的屁股。默认情况下,其只需要看见屁股那部分就可以了;但是,有时候,遇到特别迷人的屁股,其需要能够看到通过某些交互(如hover)连屁股的边缘也要看到。这就是马桶有层边缘盖出现的原因——当我需要看到全部屁屁的时候,通过掀起这个交互就可以啦!

CSS hover效果的逆向思维实现

对应的,默认情况下,我们不希望角边框出现,于是,我们默认区域大小就是那部分就OK了,当hover的时候,我们把“马桶的边缘盖掀起来”,增加可视区域面积,则边框就出现了。

其中,鼠标hover前后,元素的尺寸发生改变;由于尺寸改变,图片位置依然居中,因此,背景图片的位置也要改变;同时,由于元素本身hover前后占据没有位移,显然,hover前后元素的位置也要有相应的变化。

最最关键的问题是,默认状态下,显示的小尺寸,就是3种数值相关的变化搅合在了一起的状态。如果元素尺寸较小,hover时候变大同时要不晃动,默认就应该有个边距之类……同时因为背景在大小尺寸下的定位不一样,所以默认背景图片也要有偏移,那元素偏移与背景偏移关系是?……啊啊,智商着急的我想不过来啊~~CSS hover效果的逆向思维实现

这种感觉就像是:太上老君要求你,眼睛一睁,要出现在华山上;然后,顺利下山。我去,太上老君,你以为华山是“华科瑜伽山”的缩写吗,况且我们是凡人,要眼睛一睁就在华山上,比蜀道还难。

咋办咋办?逆向思维先出现在简单的山脚,再慢慢爬上去。时光一倒流——OK啦!

//zxx: 瑜伽山位于华中科技大学内,据说是武汉第一高山,我爬过,好像就几百米吧。

三、hover交互的逆向思维

“马桶原理”的hover效果难点在于默认的定位,有诸多的偏移与计算,一下子下不了手,我们可以逆向思维,先实现规矩的hover之后的效果,然后再乾坤大挪移。

hover之后的效果很简单的,定定高,背景定位(0 00 -50)。就像简单开着小车来到黄山脚下。然后,我们再去一点一点调试hover之后,元素尺寸改变,然后定位,然后背景偏移等,逐个击破,很快的,效果就噢啦。

您可以狠狠地点击这里:相反hover效果实现demo

CSS hover效果的逆向思维实现

下面展示代码是上面相反hover的相关代码:

.gr_iphone{width:91px;} .gr_andROId{width:101px; background-posITion:0 -50px;} .gr_iphone:hover{width:74px; background-position:-8px -4px;} .gr_android:hover{width:84px; margin-left:8px; background-position:-8px -54px;}

可以看到,hover之后的CSS属性总比hover之前多一个,而且width值以及background-position值与图片尺寸没有关联,很难直接搞清楚这些精确值。因此,先处理含边框的效果是明智的,因为更最简单更容易上手。

逆应用
下面的事情就好办对了,虽说上山容易下山难,但是,至少上去过了,路总不会走错的。同样的,要实现我们最后的效果,我们还需要再逆一次。如何逆呢?如果条件允许,直接对应的选择器调换一下就可以了。例如这里,直接有:hover和没有的调换下,如下图所示:
CSS hover效果的逆向思维实现

然后再一些细节稍微补漏下,需要的效果就大功告成了!

您可以狠狠地点击这里:hover效果逆实现的再次逆还原demo

于是,就有类似下图的效果啦:
CSS hover效果的逆向思维实现

四、总结语

如果一件事件,下手很难,结果很简单。可以试试逆向思维,从结果入手,说不定就会找到出路。这个道理在简单的CSS世界中同样适用,对于hover效果,如果下手很难,最后的效果却不难实现。我们可以换个思维,先实现结果,然后在hover实现比较难下手的那个效果,找到出路,原路返回,问题自然更加轻松解决了。

本文的例子更多是抛砖引玉。实际上,从各方面权衡来看,可能最佳的方法还是第一种最老实巴交的做法,易懂易维护,虽然牺牲的图片大小抵得上上千CSS字符。当然,有的团队更看重权衡文件大小、后期扩展,那可能抛砖引玉的例子本身就是金砖,只是因为最近金价太低才抛的。

欢迎您提供更好的本例实现方案,一起探讨,共同进步。行文仓促,文章要是有表述不准确或自以为是的地方,欢迎指正。

(本篇完)

觉得可用,就经常来吧! 脚本宝典 欢迎评论哦! html5教程,巧夺天工,精雕玉琢。小宝典献丑了!

脚本宝典总结

以上是脚本宝典为你收集整理的html5教程-CSS hover效果的逆向思维实现全部内容,希望文章能够帮你解决html5教程-CSS hover效果的逆向思维实现所遇到的问题。

如果觉得脚本宝典网站内容还不错,欢迎将脚本宝典推荐好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。