CSS hover效果的逆向思维实现 ? 张鑫旭 css hover

by zhangxinxu from http://www.zhangxinxu.com

本文地址:http://www.zhangxinxu.com/wordpress/?p=3178

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



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

实现方法很多,比方说:

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



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



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



您可以狠狠地点击这里:内标签边框色取消覆盖demo

Sprite仅两个hover状态,单层标签,clip:rect实现。您可以再次狠狠地点击这里:clip属性剪裁实现demo



像素分毫不差的效果。不过clip只能应用在绝对定位元素上,因此,该方法还是有一定的限制的。

CSS hover效果的逆向思维实现 ? 张鑫旭 css hover
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 次

  

爱华网本文地址 » http://www.aihuau.com/a/25101014/205848.html

更多阅读

用flash8制作放大镜效果的方法举例 flash放大镜效果

用flash8制作放大镜效果的方法举例与但丁讨论神曲准备工作:用PS等软件改变《与但丁讨论神曲》原图的尺寸,得到一张大图(1583*500像素)和一张小图(475*150像素),再用抠图得到一张透明的GIF格式的放大镜图片(“放大镜”的直径约为7厘米)备用

创意思维的15个常用方法 常用的逆向思维方法

创意思维的15个常用方法:创意解难法、目录法、检核表法、缺点列举法、优点列举法、希望点列举法、属性列举法、脑力激荡法、三三两两讨论法、六六讨论法、心智图法、曼陀罗法、逆向思考法...创意思维常用练习方法激发员工的创意思维

逆向思维训练 趣解大数据时代的逆向思维法

系列专题:大数据营销大数据对普通人有什么意义?最近一段时间,“大数据时代”、“互联网思维”持续成为微博微信上非常热门的话题,大有“分享不谈大数据,读尽诗书也枉然”的势头。对于公关、广告公司而言,大数据、互联网思维是一种全新的

逆向思维训练 逆向思维,创业也讲出奇制胜

在创业的路上,很多人常常会有满腹的抱负,满脑子的计划,以及许多认为需要发展的策略,如果能突破常规思维的樊篱,有意识运用与传统思维和习惯背道而驰的逆向思维方法,“反弹琵琶”,往往“曲径通幽”,取得意想不到的效果。   观念一:先站稳再

声明:《CSS hover效果的逆向思维实现 ? 张鑫旭 css hover》为网友江山给我做酒栈分享!如侵犯到您的合法权益请联系我们删除