小tip: 某简单的字符重叠与图形生成

这篇文章发布于 2012年12月26日,星期三,16:56,归类于 CSS相关。 阅读 51991 次, 今日 2 次 11 条评论

 

引言

字符重叠不是什么稀奇的东西。

如1像素错位模拟阴影效果:
字符重叠与模拟阴影效果 张鑫旭-鑫空间-鑫生活

或者powerFloat中展示的带边框三角:
powerFloat中的三角效果 张鑫旭-鑫空间-鑫生活

以及其他很多。

但是技术这东西不是豆腐,老了可以吃,臭了也可以吃;那我这里还拿着个说事作甚?

背景

今天比较有空,就看看一些站点的sprite如何规划的,于是看到新版新浪微博有这么一个sprite图片:all_iconbtn.png

其中有下图所示部分的图标效果:
新浪微博某图标标识 张鑫旭-鑫空间-鑫生活

我知道一种简单且兼容的方法,可以实现上图标出来的图标效果。这个方法就是本文要分享的小tip.

实现

实现精髓:字符重叠。
使用字符:见下图。
字符重叠使用的字符示意 张鑫旭-鑫空间-鑫生活

也就是HTML代码中的tag的前后标签.

HTML代码如下:

<strong class="gtlt">&gt;&gt;</strong>

CSS代码如下:

.gtlt{font-family:simsun; letter-spacing:-.5em; *zoom:1;}

于是就噢啦!

效果

如下:

<<

上面的实现兼容IE6+以及其他N多浏览器,且颜色随意控制(因为是字符),大小随意控制,您设置20像素大小都是可以的。

您可以狠狠地点击这里:字符重叠与大小可控的尖角图形生成demo

上面demo演示了不同字体大小,图标效果依旧良好,例如,IE6浏览器下,设置文字大小18像素,如下效果,是不是跟微博那个效果神似呢!
IE6下字符重叠18像素字体下的效果 张鑫旭-鑫空间-鑫生活

结语

因为使用的是很普通的字符,很普通的字体,同时很兼容的CSS letter-spacing. 因此,本方法可以大胆使用。
单层标签,CSS简洁,此方法的优点不言而喻。

局限,貌似只能让字符水平重叠。好像有CSS可以控制文字竖着写的,恩……我就不深入了~~啦啦啦啦~~

举一反三,其他一些图形效果,您也可以试试这个方法。

(本篇完)

分享到:


发表评论(目前11 条评论)

  1. lisachen说道:

    <<
    >>

    chrome下第二个比第一个粗

  2. Hannah说道:

    当这个箭头写在a标签里的时候,hover的颜色变化比较诡异呢,只有一个&gt会变色,另一个不会……

  3. Michael J.说道:

    新浪微博的top nav用的这个

    写css控制的margin通过裁切来实现的箭头

  4. aster说道:

    不兼容FF和chrome,思路不错,适用性不强啊

  5. 一路说道:

    思路不错,顶!

  6. 梦幻神化说道:

    可惜受到字体库的影响,没办法保证所有电脑的显示都完美,但如果说调用谷歌在线的字体库又划不来。但这个想法不错(∩_∩)

  7. 一丝说道:

    木有 simsun 的 电脑表示亚历山大,字符每个字体表现出来还是有一定的差异的。

  8. Jet说道:

    如果电脑上没有宋体的话会很难看

  9. VVG说道:

    微博块来挖人啊