CSS hover效果的逆向思维实现 ? 张鑫旭 css hover
本文地址:http://www.zhangxinxu.com/wordpress/?p=3178
一、一个很简单的效果实现
很简单,鼠标移上去,出现圆角的边框线。
实现方法很多,比方说:
4状态全部呈现在Sprite上,这最好理解,只要关心background-position位置即可,一层标签就可以搞定。
您可以狠狠地点击这里:牺牲背景图片大小的基本实现demo
Sprite仅两个hover状态(见下图,下同),牺牲额外一层标签,双层标签,内层标签使用实色边框取巧覆盖(并不推荐,无法应用于其他背景色场景,不具体展示)。
您可以狠狠地点击这里:内标签边框色取消覆盖demo
Sprite仅两个hover状态,单层标签,clip:rect实现。您可以再次狠狠地点击这里:clip属性剪裁实现demo
像素分毫不差的效果。不过clip只能应用在绝对定位元素上,因此,该方法还是有一定的限制的。
Sprite仅两个hover状态,单层标签,通过控制hover前后元素的精确尺寸、背景位置、自身位置实现效果。这个方法就是本文抛砖引玉之所在。
二、抛什么砖、引什么玉
上段方法4要实现的原理也可以称为CSS hover的马桶原理。这是有典故的:
一个黑人在炎热沙漠中被活活干死了,去了天堂上帝问他有什么愿望,黑人说:“我希望下辈子变得很白,远离阳光,每天都有水喝!”上帝答应了他的要求,于是这位黑人下辈子变成了……抽水马桶。
黑人变成马桶后,兴趣变成了看美女的屁股。默认情况下,其只需要看见屁股那部分就可以了;但是,有时候,遇到特别迷人的屁股,其需要能够看到通过某些交互(如hover)连屁股的边缘也要看到。这就是马桶有层边缘盖出现的原因——当我需要看到全部屁屁的时候,通过掀起这个交互就可以啦!
对应的,默认情况下,我们不希望圆角边框出现,于是,我们默认区域大小就是那部分就OK了,当hover的时候,我们把“马桶的边缘盖掀起来”,增加可视区域面积,则边框就出现了。
其中,鼠标hover前后,元素的尺寸发生改变;由于尺寸改变,图片位置依然居中,因此,背景图片的位置也要改变;同时,由于元素本身hover前后占据没有位移,显然,hover前后元素的位置也要有相应的变化。
最最关键的问题是,默认状态下,显示的小尺寸,就是3种数值相关的变化搅合在了一起的状态。如果元素尺寸较小,hover时候变大同时要不晃动,默认就应该有个边距之类……同时因为背景在大小尺寸下的定位不一样,所以默认背景图片也要有偏移,那元素偏移与背景偏移关系是?……啊啊,智商着急的我想不过来啊~~
这种感觉就像是:太上老君要求你,眼睛一睁,要出现在华山上;然后,顺利下山。我去,太上老君,你以为华山是“华科瑜伽山①”的缩写吗,况且我们是凡人,要眼睛一睁就在华山上,比蜀道还难。
咋办咋办?逆向思维!先出现在简单的山脚,再慢慢爬上去。时光一倒流——OK啦!
//zxx: 瑜伽山位于华中科技大学内,据说是武汉第一高山,我爬过,好像就几百米吧。
三、hover交互的逆向思维
“马桶原理”的hover效果难点在于默认的定位,有诸多的偏移与计算,一下子下不了手,我们可以逆向思维,先实现规矩的hover之后的效果,然后再乾坤大挪移。
hover之后的效果很简单的,定宽定高,背景定位(0 0与0 -50)。就像简单开着小车来到黄山脚下。然后,我们再去一点一点调试hover之后,元素尺寸改变,然后定位,然后背景偏移等,逐个击破,很快的,效果就噢啦。
您可以狠狠地点击这里:相反hover效果实现demo
下面展示代码是上面相反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和没有的调换下,如下图所示:
然后再一些细节稍微补漏下,需要的效果就大功告成了!
您可以狠狠地点击这里:hover效果逆实现的再次逆还原demo
于是,就有类似下图的效果啦:
四、总结语
如果一件事件,下手很难,结果很简单。可以试试逆向思维,从结果入手,说不定就会找到出路。这个道理在简单的CSS世界中同样适用,对于hover效果,如果下手很难,最后的效果却不难实现。我们可以换个思维,先实现结果,然后在hover实现比较难下手的那个效果,找到出路,原路返回,问题自然更加轻松解决了。
本文的例子更多是抛砖引玉。实际上,从各方面权衡来看,可能最佳的方法还是第一种最老实巴交的做法,易懂易维护,虽然牺牲的图片大小抵得上上千CSS字符。当然,有的团队更看重权衡文件大小、后期扩展,那可能抛砖引玉的例子本身就是金砖,只是因为最近金价太低才抛的。
欢迎您提供更好的本例实现方案,一起探讨,共同进步。行文仓促,文章要是有表述不准确或自以为是的地方,欢迎指正。
原创文章,转载请注明来自张鑫旭-鑫空间-鑫生活[http://www.zhangxinxu.com]
本文地址:http://www.zhangxinxu.com/wordpress/?p=3178
(本篇完)
如果您觉得本文的内容对您的学习有所帮助:
相关文章
IE6下png背景不透明问题的综合拓展 (0.278)
对html与body的一些研究与理解 (0.278)
页面可用性之outline轮廓外框的一些研究 (0.278)
CSS clip:rect矩形剪裁功能及一些应用介绍 (0.278)
您可能不知道的CSS元素隐藏“失效”以其妙用 (0.278)
你到了第几层?图片式标题、按钮与隐藏文本 (0.278)
酷酷的jQuery鼠标悬停图片放大切换显示效果 (0.167)
jQuery - 鼠标经过(hover)事件的延时处理 (0.167)
MooTools和jQuery库继承实现class切换对比 (0.167)
小卖弄:开心网标签词观点交互的CSS实现 (0.167)
分享到:
1
标签: clip, hover, 文字偏移, 背景定位, 逆向思维
这篇文章发布于 2013年04月18日,星期四,00:51,归类于 css相关。 阅读 10069 次, 今日 27 次
更多阅读
IOS_视图实现圆角效果的三种方法及比较 css实现圆角边框
通过代码,至少有三种方法可以为视图加上圆角效果。附例子:https://github.com/weipin/RoundedCorner方法一、layer.cornerRadius第一种方法最简单,通过层对象的cornerRadius属性实现圆角效果,代码如下:view.layer.cornerRadius = 8.0;vie
用flash8制作放大镜效果的方法举例 flash放大镜效果
用flash8制作放大镜效果的方法举例与但丁讨论神曲准备工作:用PS等软件改变《与但丁讨论神曲》原图的尺寸,得到一张大图(1583*500像素)和一张小图(475*150像素),再用抠图得到一张透明的GIF格式的放大镜图片(“放大镜”的直径约为7厘米)备用
创意思维的15个常用方法 常用的逆向思维方法
创意思维的15个常用方法:创意解难法、目录法、检核表法、缺点列举法、优点列举法、希望点列举法、属性列举法、脑力激荡法、三三两两讨论法、六六讨论法、心智图法、曼陀罗法、逆向思考法...创意思维常用练习方法激发员工的创意思维
逆向思维训练 趣解大数据时代的逆向思维法
系列专题:大数据营销大数据对普通人有什么意义?最近一段时间,“大数据时代”、“互联网思维”持续成为微博微信上非常热门的话题,大有“分享不谈大数据,读尽诗书也枉然”的势头。对于公关、广告公司而言,大数据、互联网思维是一种全新的
逆向思维训练 逆向思维,创业也讲出奇制胜
在创业的路上,很多人常常会有满腹的抱负,满脑子的计划,以及许多认为需要发展的策略,如果能突破常规思维的樊篱,有意识运用与传统思维和习惯背道而驰的逆向思维方法,“反弹琵琶”,往往“曲径通幽”,取得意想不到的效果。 观念一:先站稳再