css中怎么用图片定位把所有图标放在一张图上

发布时间:2021-07-27 14:28:21 作者:chen
来源:亿速云 阅读:208

本篇内容主要讲解“css中怎么用图片定位把所有图标放在一张图上”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“css中怎么用图片定位把所有图标放在一张图上”吧!

如今做网页为了使网站丰富多彩,富于表现力,往往需要应用大量的图片/图标。如何处理这些图片,使其尽量不影响网页载入,解析等速度,是一个不大不小的问题。如果你的网站用各种图标图案装饰的靓丽无比,但是需要等待较长的时间加载,那么相信很多用户会等不及而离开。尽量将图片做的小些,可能是大部分人选择的解决之道。但是100张1kb的图片加载与一张100kb的图片加载,这之间又是不同的,这涉及到网站服务器的同时连接数,网络质量等。但是,显然,加载一张图片要远比加载多张图片简便的多。

还有最重要的一点,就是涉及到用户动作才表现的图片,例如鼠标移上/移下的图片切换,由于是由动作触发的,所以在动作触发前是不会加载的,而当需要时再从服务器下载,这之间又需要一定的时间,如果图片较大,此时网络质量又不太好,就会出现页面空白。而以上这一切,如果你将所有需要的图片放到一张图片上,这些问题就都不会有了。因为在网页加载时这张图片就已经从服务器上下载来了,所以不会出现丢失,未加载等现象。

对于老鸟来说,这一点可能已经成为一种意识,他们都很自觉,下意识的就会这么做,但是对于新手,初接触网页的人来说,可能还停留在用到哪张图片就单独处理哪张图片的阶段。我当然也是新手,之前在做网站右上角的一张图片切换时,就是做了两张不同的图片,结果往往容易碰到网速不好时,第二张图片不能及时加载上来。于是今天便将其处理了一下,整到了一张图片上。我比较懒,后期往网站上添加一些内容时,懒得去动以前的东西,所以后期某些地方加入的图标啥的都是单独一张小图标加上去的,也没与之前的整合。但是,有一些尺寸稍大的,就不行了,就像我今天处理的,总是有延迟。现在我就拿其做个例子,说说css中图片定位及整合的好处。

为了使某处富于表现力,比如菜单,导航等,往往会用到鼠标移上移下的不同样式表现,最简单的就是图片切换了。比如两张图片,一张用于鼠标未指向时,另一张用于鼠标移上去时。为了使第二张图片无缝载入,就需要将这两张图片放到一起。比如本站右上角的那图案,初始时是灰色,鼠标移上则变为彩色。即是用到了此张图片:

css中怎么用图片定位把所有图标放在一张图上 

css中定义:

代码如下:


.ltlogo a{background:url("img/ltlogo.gif") no-repeat left 15px;}
.ltlogo a:hover{background:url("img/ltlogo.gif") no-repeatleft bottom;}


对了,有必要说一下网页对于图片的处理,seo中建议图片尽量不直接写入网页。对于需要用一张图片,传统做法是<img src=“源图片”/>引入。因为图片搜索引擎无法收录,所以我推荐用css表现。如何做呢?举个实例吧:

比如要将一张200X50的图片放入页面,传统做法是

代码如下:


<img src=“源图片”height=”200px” width=”50px”/>


而用css,则可以在页面中写入<span id=”img”></span>,css中这样写:

代码如下:


#img{display:block;width:50px;height:200px;background:url(源图片);}


为什么要用display:block;?display:block;就是将行内元素强行转化为块级元素。此处作用就是将整个宽200高50的区域整个块级化。

回到正文来,我此处就是用css装入这张图片的。上面css中我只写了重要的部分,其余省略。加粗部分“left 15px”就是定位图片了,相比较而言,这个只有两张图片的比较容易。left即是水平方向从最左端加载,15px是针对我自己的网站而言,由于图片所属整个层区域高度相对图片较大,所以需要图片往下靠一点。你可以理解为在整张图片上高度增加了15px。

第二个“left bottom”,就是鼠标移上去时的所需图片。第二张图片我放在最底部,所以垂直方向直接用bottom从底部定位。

上面是我自己的例子,关于大量处于同一张图片上的定位,以及如何处理位于同一张图片上的各个图标更容易等,下次再说。

到此,相信大家对“css中怎么用图片定位把所有图标放在一张图上”有了更深的了解,不妨来实际操作一番吧!这里是亿速云网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

推荐阅读:
  1. 图片如何拼接在一张图上
  2. 如何使用CSS3设计地图上的雷达定位提示效果

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

css

上一篇:Navicat如何解决连接MySQL时报10060、1045错误及my.ini位置的问题

下一篇:MySQL中怎么设置查询超时

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》