本文初始编辑地址,源自我的CSDN博客:我的CSDN博客
最近在做一个项目因为要用bootstrap,需要对第三方分享的图标设计两个款式,最终需求的效果如下:
一、需求分析
1.在PC端,要求用font字符来实现第三方分享的图标,并且鼠标经过时,设定hover效果:
2.在小屏幕设备上,需要设定另外一种款式:
二、思路分析
理清需求以后,下面来看是如何实现的:
首先,需要点击这些第三方应用的图片或者字符,来实现相应的跳转,例如点击QQ,进入QQ的分享界面。
如果要完成这一步,需要去每个平台的官网获取分享组件,其实就是人家官方定义好的js API接口。整个页面如果只需要1个2个分享图标还好,要是十几个,20个图标,估计页面会乱七八糟自己看着都糟心。
于是这里安利百度share,集成了大多数的第三方share API,非常的方便,省事,复制,粘贴,一气呵成,但是效果可能就不尽人意了。
看到这里,我以为我打开了二零零年的一张网页,真的,这图标,这32*32的icon清晰度,真的让我很难受。
首先推荐一几个icon库,这些icon非常精美,并且实时更新:
1.阿里妈妈icon库:
http://www.iconfont.cn/manage/index?spm=a313x.7781069.1998910419.8&manage_type=myicons&icontype=histories&keyword=
2.Easyicon
http://www.easyicon.net/
在这里可以下载相应的icon,推荐下载SVG,这个格式的图片制作字体很方便。
看一下百度官方的代码
1 | <div class="bdsharebuttonbox"> |
不难发现,其实a标签的父div:bdsharebuttonbox已经提前为a标签设置好了样式和背景图了。
这里我们下载好图标,能否直接插入到<a>
标签中,然后 实现对应图片的替换呢?显然不行,因为百度通过class类设定好的背景图片,不会被框架内的图片所覆盖,给大家演示一下错误的示范:
不仅没有变美,反而更丑了。
三、功能实现
3.1 将原始图标替换为图片图标
怎么办呢?其实我们应该直接设定对应class类的背景图,并且加权!important,就可以完美实现背景图的替换了。
1 | .bd_qzone{background:url(./img/qq.png) !important} |
这里要说明一下,百度的Share api第三方的图标,全部都是32*32的,因此如果你的图片过于清晰(分辨率太高),应该增加backgrond-size:cover !important ,来填充。
1 | .bd_qzone{background:url(./img/qq.png) !important;backgrond-size:cover !important } |
这样,可以实现一个比较好看的图标分享小模块了:
这里我用的图标是128*128的,即便将网页放大10倍,也没有锯齿感。
3.2字符图标完成Share 功能的实现
字符图标相比于图片图标,更加节省资源,而且兼容性更棒!(IE4+都支持字符图标)。
我们首先去阿里妈妈或者easyicon下载好对应的透明的svg文件,接着到:
https://icomoon.io/app/#/select
这个网站很牛逼,可以将图片转为各种浏览器看得懂的字符文件
(1)我们打开网站,最上方点击import Icons,上传自己的图标图片文件
(2)上传好以后, 可以按铅笔图标对文件进行编辑,比如命名,方向结构等等
(3)上传好以后,点击下面的Generate Font,下载已经转换好的字体文件
(4)下载好以后解压,用记事本打开style.css的文件,复制到你的html页面中的
1 | ![这里写图片描述](http://img.blog.csdn.net/20171103180119963?watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvcXFfMjAyNjQ4OTE=/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/SouthEast) |
复制好如下:
1 |
|
最终的效果如下:
我通过js/jq又添加了hover效果,这个界面看上去就舒服多了。
今天研究了一天这个问题,从最初的不明白第三方分享的原理,到现在可以改变默认样式,我觉得今天收获还是挺多的,对CSS、JS都有了更进一步的理解。
觉得文章有用?点击下方打赏,鼓励作者更好的写作!