如今做网页为了使网站丰富多彩,富于表现力,往往需要应用大量的图片/图标。如何处理这些图片,使其尽量不影响网页载入,解析等速度,是一个不大不小的问题。如果你的网站用各种图标图案装饰的靓丽无比,但是需要等待较长的时间加载,那么相信很多用户会等不及而离开。尽量将图片做的小些,可能是大部分人选择的解决之道。但是100张1kb的图片加载与一张100kb的图片加载,这之间又是不同的,这涉及到网站服务器的同时连接数,网络质量等。但是,显然,加载一张图片要远比加载多张图片简便的多。
还有最重要的一点,就是涉及到用户动作才表现的图片,例如鼠标移上/移下的图片切换,由于是由动作触发的,所以在动作触发前是不会加载的,而当需要时再从服务器下载,这之间又需要一定的时间,如果图片较大,此时网络质量又不太好,就会出现页面空白。而以上这一切,如果你将所有需要的图片放到一张图片上,这些问题就都不会有了。因为在网页加载时这张图片就已经从服务器上下载来了,所以不会出现丢失,未加载等现象。
对于老鸟来说,这一点可能已经成为一种意识,他们都很自觉,下意识的就会这么做,但是对于新手,初接触网页的人来说,可能还停留在用到哪张图片就单独处理哪张图片的阶段。我当然也是新手,之前在做网站右上角的一张图片切换时,就是做了两张不同的图片,结果往往容易碰到网速不好时,第二张图片不能及时加载上来。于是今天便将其处理了一下,整到了一张图片上。我比较懒,后期往网站上添加一些内容时,懒得去动以前的东西,所以后期某些地方加入的图标啥的都是单独一张小图标加上去的,也没与之前的整合。但是,有一些尺寸稍大的,就不行了,就像我今天处理的,总是有延迟。现在我就拿其做个例子,说说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中图片定位及整合的好处。
为了使某处富于表现力,比如菜单,导航等,往往会用到鼠标移上移下的不同样式表现,最简单的就是图片切换了。比如两张图片,一张用于鼠标未指向时,另一张用于鼠标移上去时。为了使第二张图片无缝载入,就需要将这两张图片放到一起。比如本站右上角的那图案,初始时是灰色,鼠标移上则变为彩色。即是用到了此张图片:
比如要将一张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,图片定位
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件!
如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
暂无“浅谈css中图片定位之所有图标放在一张图上”评论...
《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线
暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。
艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。
《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。
更新动态
2024年11月24日
2024年11月24日
- 凤飞飞《我们的主题曲》飞跃制作[正版原抓WAV+CUE]
- 刘嘉亮《亮情歌2》[WAV+CUE][1G]
- 红馆40·谭咏麟《歌者恋歌浓情30年演唱会》3CD[低速原抓WAV+CUE][1.8G]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[320K/MP3][193.25MB]
- 【轻音乐】曼托凡尼乐团《精选辑》2CD.1998[FLAC+CUE整轨]
- 邝美云《心中有爱》1989年香港DMIJP版1MTO东芝首版[WAV+CUE]
- 群星《情叹-发烧女声DSD》天籁女声发烧碟[WAV+CUE]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[FLAC/分轨][748.03MB]
- 理想混蛋《Origin Sessions》[320K/MP3][37.47MB]
- 公馆青少年《我其实一点都不酷》[320K/MP3][78.78MB]
- 群星《情叹-发烧男声DSD》最值得珍藏的完美男声[WAV+CUE]
- 群星《国韵飘香·贵妃醉酒HQCD黑胶王》2CD[WAV]
- 卫兰《DAUGHTER》【低速原抓WAV+CUE】
- 公馆青少年《我其实一点都不酷》[FLAC/分轨][398.22MB]
- ZWEI《迟暮的花 (Explicit)》[320K/MP3][57.16MB]