您现在的位置是:网站首页> 编程资料编程资料
浅谈css中图片定位之所有图标放在一张图上CSS Transition通过改变Height实现展开收起元素从QQtabBar看css命名规范BEM的详细介绍css实现两栏布局,左侧固定宽,右侧自适应的多种方法CSS 实现Chrome标签栏的技巧CSS实现两列布局的N种方法CSS实现隐藏搜索框功能(动画正反向序列)CSS3中Animation实现简单的手指点击动画的示例详解CSS中的特指度和层叠问题详解overflow:hidden的作用(溢出隐藏、清除浮动、解决外边距塌陷)关于CSS浮动与取消浮动的问题
2021-09-06
977人已围观
简介 本文为大家介绍下如何将所有图标放在一张图上,这里需要学习下css中的图片定位,下面有个不不错的示例,大家可以参考下
如今做网页为了使网站丰富多彩,富于表现力,往往需要应用大量的图片/图标。如何处理这些图片,使其尽量不影响网页载入,解析等速度,是一个不大不小的问题。如果你的网站用各种图标图案装饰的靓丽无比,但是需要等待较长的时间加载,那么相信很多用户会等不及而离开。尽量将图片做的小些,可能是大部分人选择的解决之道。但是100张1kb的图片加载与一张100kb的图片加载,这之间又是不同的,这涉及到网站服务器的同时连接数,网络质量等。但是,显然,加载一张图片要远比加载多张图片简便的多。
还有最重要的一点,就是涉及到用户动作才表现的图片,例如鼠标移上/移下的图片切换,由于是由动作触发的,所以在动作触发前是不会加载的,而当需要时再从服务器下载,这之间又需要一定的时间,如果图片较大,此时网络质量又不太好,就会出现页面空白。而以上这一切,如果你将所有需要的图片放到一张图片上,这些问题就都不会有了。因为在网页加载时这张图片就已经从服务器上下载来了,所以不会出现丢失,未加载等现象。
对于老鸟来说,这一点可能已经成为一种意识,他们都很自觉,下意识的就会这么做,但是对于新手,初接触网页的人来说,可能还停留在用到哪张图片就单独处理哪张图片的阶段。我当然也是新手,之前在做网站右上角的一张图片切换时,就是做了两张不同的图片,结果往往容易碰到网速不好时,第二张图片不能及时加载上来。于是今天便将其处理了一下,整到了一张图片上。我比较懒,后期往网站上添加一些内容时,懒得去动以前的东西,所以后期某些地方加入的图标啥的都是单独一张小图标加上去的,也没与之前的整合。但是,有一些尺寸稍大的,就不行了,就像我今天处理的,总是有延迟。现在我就拿其做个例子,说说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中建议图片尽量不直接写入网页。对于需要用一张图片,传统做法是
引入。因为图片搜索引擎无法收录,所以我推荐用css表现。如何做呢?举个实例吧:
比如要将一张200X50的图片放入页面,传统做法是

而用css,则可以在页面中写入,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中图片定位及整合的好处。
为了使某处富于表现力,比如菜单,导航等,往往会用到鼠标移上移下的不同样式表现,最简单的就是图片切换了。比如两张图片,一张用于鼠标未指向时,另一张用于鼠标移上去时。为了使第二张图片无缝载入,就需要将这两张图片放到一起。比如本站右上角的那图案,初始时是灰色,鼠标移上则变为彩色。即是用到了此张图片:

css中定义:
复制代码
代码如下:.ltlogo a{background:url("img/ltlogo.gif") no-repeat left 15px;}
.ltlogo a:hover{background:url("img/ltlogo.gif") no-repeatleft bottom;}
对了,有必要说一下网页对于图片的处理,seo中建议图片尽量不直接写入网页。对于需要用一张图片,传统做法是
比如要将一张200X50的图片放入页面,传统做法是
复制代码
代码如下:而用css,则可以在页面中写入,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从底部定位。
上面是我自己的例子,关于大量处于同一张图片上的定位,以及如何处理位于同一张图片上的各个图标更容易等,下次再说。当然,我是初学者,所用名词、术语有所不当,所说内容有错误之处,老鸟经过,还望指教。网页制作
相关内容
- IE下Css圆角没有的解决方法
- css判读浏览器类型的代码CSS Transition通过改变Height实现展开收起元素从QQtabBar看css命名规范BEM的详细介绍css实现两栏布局,左侧固定宽,右侧自适应的多种方法CSS 实现Chrome标签栏的技巧CSS实现两列布局的N种方法CSS实现隐藏搜索框功能(动画正反向序列)CSS3中Animation实现简单的手指点击动画的示例详解CSS中的特指度和层叠问题详解overflow:hidden的作用(溢出隐藏、清除浮动、解决外边距塌陷)关于CSS浮动与取消浮动的问题
- CSS div布局需要注意的两点css实现文本和div居中对齐详细讲解示例通过position定位实现div底端对齐多个div中table的tdwidth设置一样也不法对齐图片在div中垂直和水平同时对齐的实现方法DIV和SPAN垂直居中对齐的实现方法将一个绝对定位的div水平垂直居中对齐div中加入span右对齐后出现换行显示两种解决思路div中子div在firefox ie 水平居中对齐 CSS让图片垂直居中和底端对齐的代码-CSS教程-网页制作-网页教学网html5 div布局与table布局详解
- 完美实现文字置于图片之上且背景半透明CSS Transition通过改变Height实现展开收起元素从QQtabBar看css命名规范BEM的详细介绍css实现两栏布局,左侧固定宽,右侧自适应的多种方法CSS 实现Chrome标签栏的技巧CSS实现两列布局的N种方法CSS实现隐藏搜索框功能(动画正反向序列)CSS3中Animation实现简单的手指点击动画的示例详解CSS中的特指度和层叠问题详解overflow:hidden的作用(溢出隐藏、清除浮动、解决外边距塌陷)关于CSS浮动与取消浮动的问题
- 用ul li实现边框重合并附带鼠标经过效果鼠标经过图片显示边框的CSS代码基于jquery实现的鼠标经过背景滑动导航菜单特效源码jquery实现的鼠标经过悬浮相册缩略图是在鼠标右侧显示大图特效源码jquery实现的鼠标经过图片上浮显示产品更多说明相册特效源码基于jquery实现的网页通栏banner切换代码+鼠标经过滑出右侧在线客服特jQuery实现的鼠标经过标题向上弹出特效源码jQuery+hover 鼠标经过显示边框动画特效源码
- 用CSS创建打印页面的具体步骤CSS Transition通过改变Height实现展开收起元素从QQtabBar看css命名规范BEM的详细介绍css实现两栏布局,左侧固定宽,右侧自适应的多种方法CSS 实现Chrome标签栏的技巧CSS实现两列布局的N种方法CSS实现隐藏搜索框功能(动画正反向序列)CSS3中Animation实现简单的手指点击动画的示例详解CSS中的特指度和层叠问题详解overflow:hidden的作用(溢出隐藏、清除浮动、解决外边距塌陷)关于CSS浮动与取消浮动的问题
- 纯css实现的颜色扇附图CSS Transition通过改变Height实现展开收起元素从QQtabBar看css命名规范BEM的详细介绍css实现两栏布局,左侧固定宽,右侧自适应的多种方法CSS 实现Chrome标签栏的技巧CSS实现两列布局的N种方法CSS实现隐藏搜索框功能(动画正反向序列)CSS3中Animation实现简单的手指点击动画的示例详解CSS中的特指度和层叠问题详解overflow:hidden的作用(溢出隐藏、清除浮动、解决外边距塌陷)关于CSS浮动与取消浮动的问题
- 通过css属性margin:auto让Div中的Table居中CSS深入学习之让你认识不一样的marginCSS中margin边界叠加问题及解决方案CSS margin全面了解浅谈css margin重叠CSS 之margin知识点(必看)css布局之负margin妙用及其他实现细说CSS中margin属性的使用 深入解析CSS中margin属性的使用CSS中使用负margin值来调整居中位置CSS属性探秘系列(六):margin
- 强制CSS !important使用介绍浅谈CSS 权值 层叠 重要性(!important)css中提升优先级属性!important的用法总结从可维护性角度考虑css的!important规则的可用性css中!important的作用(IE6 IE7 FF)及其原理CSS优先级和!important与IE6的BUG讨论及解决方案CSS下!important属性 CSS中提升优先级属性!important的用法问题总结
- 你应该知道的30个css选择器css3中transform属性实现的4种功能详解CSS3.0(Cascading Style Sheet) 层叠级联样式表纯CSS3实现div按照顺序出入效果CSS3实现列表无限滚动/轮播效果css3 利用transform-origin 实现圆点分布在大圆上布局及旋转特效CSS3实现的侧滑菜单CSS3实现的3D隧道效果用CSS3画一个爱心css3 实现文字闪烁效果的三种方式示例代码六种css3实现的边框过渡效果