用手机流量给电脑上网上网网页太大,无法缩小和移动怎么办

家里的网不知道怎么回事,是移动的。我用手机上网,有的网页都打不开,说网络错误。但用手机4G网就可以_百度知道移动SEO之如何提高移动端网站打开速度方法和技巧 - 泪雪博客
一个网站的打开速度往往决定着你是否有机会留住访客,首先是抛开网站内容,那么就是网站的加载速度了,一个在3秒钟内如果都还没有打开的网站是绝对留不住访客的,除非你这篇文章内容有极其高的阅读价值,否则你连留住用户的可能都没有。
80%的网民对移动端的浏览体验感到失望,当体验提升时,他们会在智能手机上花费更多的时间。64%的智能手机用户希望网站可以在3秒内加载完毕,但是有很多的网站打开速度却在6秒钟以上,那么这就成为移动网站SEO优化的一个要点,也是子凡觉得移动端网站应该在这方面做得更好的用户体验,子凡作为一个追求极致的人来说,是非常受不了这样慢的速度。其实在子凡前两天开始写优化的时候就写提及过网站的加载速度问题,所以还是准备仔细的给大家分析一下。
一、移动端用户下载速度研究和分析
从专业的角度来研究下究竟是什么影响了智能手机上的网页加载速度吧,最明显的原因是智能机的网速,最佳情况下,移动端用户所使用的是3G与4G上网。
在国内,使用3G网络的人数较多,而使用4G网络的人可能算是比较少数的,就算是4G网络,可能也不会用过多的流量来浏览网页,这个是重点吧!毕竟在国内的上网资费来说还是比较贵的。而从子凡自己本身来说,拥有一张移动4G卡,但是却用着那个当年追求发烧的小米2,所以网络也就处于2G时代,所以流量网页的几率也就变小了,平时都只是会在WIFI网络下浏览网页的。
从大众对手机网络的使用中,使用3G,4G上网的人还是偏多,2G已经开始逐步减少,那么对于像子凡这样感觉流量资费较贵的人群来说,浏览网页就希望越简单越好,越少的加载对用户的流量就越节约,这就是用户体验。
244 KB/s 3G用户平均网速值 (0.24 MB/s)
756 KB/s 4G用户平均网速值(0.76 MB/s)
如果把上述值乘以移动用户等待时间4秒,这意味着网站对于3G用户来说最大为1mb,而4G用户为3mb。
然而下载速度并不是瓶颈,网络延迟及智能机的内存与cpu才是瓶颈,即使手机可以在4秒内下载完1mb,页面也要花费更长的时间去加载,因为手机需要接收并解析代码与图片。
在桌面端,下载文件只占显示网站时间的20%,其余时间花费在解析http请求,获取样式表,脚本文件及图片上,由于移动端的cpu,内存与缓存跟桌面端完全无法相提并论,这些在手机上会花费更长的时间。
二、怎样优化和减少网站加载时间呢?
其实这个子凡在昨天的《》一文中也有提到,这里就算是对昨天内容的一个拓展和提升吧!
构建一个快速的网站,就是一个做出艰难决定与砍掉非核心体验的过程,如果某一项需求价值不大,去掉之,这个原则适用于所有开发阶段,尤其是规划和编码时。
减少依赖文件:更少的文件意味着更少的http请求与更快的加载时间。
降低图片大小:适应与调整高分辨率图片,在额外的下载时间中占居榜首,占用了宝贵的内存与处理资源。
减轻客户端负担:最佳实践是重新思考你的javascript,并使之降低到最小尺寸。
三、如何减少和优化网站冗余代码
在很多的网页中,你看不到的东西可能有很多,但是却不一定是这个网页所需要的,如果你想为移动端用户隐藏图片,display:none与visibility:hidden是不能阻止文件下载的,测试下面的代码:
&div style=&display:&&
&img src=&none.png& /&
&div style=&visibility:&&
&img src=&hidden.png& /&
这也就是之前子凡在《》一文中提及的不建议使用自适应做移动页面的适配的原因,自适应本身就是通过CSS样式来隐藏和显示在不同屏幕大小下的匹配罢了,虽然说这也是一种流行的网页设计,但是并不是适用与所有的网站,大家都选择性的去使用吧!子凡这里也只是发表自己的个人体验感想而已。
其实也有一些替代方案,就是是利用css加载背景图片的方法来实现,利用media query媒体查询来通过条件隐藏图片,这个技术就是根据设备来条件加载特定的图片。
&meta name=&viewport& content=&width=device-width&&
@media (max-width:600px) {
.image {display:}
@media (min-width:601px) {
.image {background-image: url(image1.jpg);}
&div class=&image&&&/div&
四、利用CSS3代替图片
圆角,阴影,渐变填充等,这些样式不需要使用图片,可以减少http请求,加快加载时间。CSS3可以减少http请求,但增加了处理负荷,css3带来的处理时间很小,但不能不考虑,特别注意box-shadow对处理时间的影响最大。
五、其它子凡感觉不太常用有比较常见的优化点
1.字体图标:现在很多网站为了减少网站图标的使用,所以使用字体图标来解决,总的效果来看还是挺不错的,单独的Web字体,对于所有图标来讲,HTTP请求的数量可以减少到一个,如果Web字体使用数据URI(如上所述)嵌入页面,HTTP请求可以减少到零,这正是WordPress使用的技术。子凡最近在开发一个网页也有使用到这几效果,效果是挺不错,但是如果网站中使用不多的话建议就不使用这个了。
2.避免内联iframe:每一个内联框架(iframe)都会生成一个HTTP请求,这是在iframe内没有另外依赖资源的情况下,这是我们做一个快速测试,比较一个iframe只含有文本。包含一个iframe增加了将近0.2s的加载时间,为了保证web站点加载迅速,最好不要使用iframe。当然这个在移动端网站应该是非常少使用的,子凡经常见到的就是在PC端用这个的还挺多的。
3.如何减少客户端处理:Javascript对加载时间的影响,在移动端较小的内存,cpu及缓存下会表现得更明显,通常,我们要重新思考javascript的使用,并保持其在最小尺寸。
4.服务器端后端技术:
除了优化前端,服务器端技术也可以用来加速加载时间,这些技术都值得考虑,如以下几点:
(1)、缓存HTTP重定向来加速重复访问;
(2)、合并HTTP重定向链来减少重定向;
(3)、使用HTTP压缩来减少数量的字节(Gzip或缩小)。
写在最后:为了满足移动用户的高期望,你需要对网站针对移动设备进行优化,在3秒或更少的时间里加载完毕,最好的方式来达到4秒这个魔术时间,是通过减少JavaScript和优化HTML、CSS和图像,保持智能手机上最少的处理负荷。对于移动网站SEO优化提速来看,依然适用与PC端网站,大家可以相互的利用这些优化的技巧和方法。
真的是不写不知道,写着写着又是长篇大论了,感觉其实有很多细节可以写的,但是为了给大家阅读时带来一个良好的效果和阅读质量,所以子凡还是觉得应该一定程度的控制文章的篇幅长度。所以到此就结束啦!如何让你的网站在移动端健步如飞 - 文章 - 伯乐在线
& 如何让你的网站在移动端健步如飞
最近一项研究表明,80%的网民对移动端的浏览体验感到失望,同时当体验提升时,他们会在智能手机上花费更多的时间。
这不奇怪,因为64%的智能手机用户希望网站可以在4秒内加载完毕,但一半的网站花费了二倍以上的时间,达到了9秒。这篇文章会阐述一些可以使你的网站在移动端跑得更快的技术。
移动端用户的下载速度
让我们来研究下究竟是什么影响了智能手机上的网页加载速度。
最明显的原因是智能机的网速。最佳情况下,移动端用户使用3g与4g上网。在美国,57%的用户使用3g上网,27%的用户使用4g。在加拿大,4g用户更少。而在英国,4g还是新鲜事物。Pcworld的研究表明,在美国,3g平均下载速度为2mbps,4g则为6.2mbps。ofcom的研究显示,在英国3g的下载速度为2.1mbps。北美和欧洲以外的连接速度一般较慢。1mpbs可换算为122kb每秒,或者0.12mb每秒,因此以上的数据可以转换如下:
244 KB/s 3G用户平均网速值 (0.24 MB/s)
756 KB/s 4G用户平均网速值(0.76 MB/s)
如果把上述值乘以移动用户等待时间4秒,这意味着网站对于3g用户来说最大为1mb,而4g用户为3mb。
然而下载速度并不是瓶颈,网络延迟及智能机的内存与cpu才是瓶颈。即使手机可以在4秒内下载完1mb,页面也要花费更长的时间去加载,因为手机需要接收并解析代码与图片。
在桌面端,下载文件只占显示网站时间的20%,其余时间花费在解析http请求,获取样式表,脚本文件及图片上。由于移动端的cpu,内存与缓存跟桌面端完全无法相提并论,这些在手机上会花费更长的时间。
怎样减少加载时间
构建一个快速的网站,就是一个做出艰难决定与砍掉非核心体验的过程。如果某一项需求价值不大,去掉之。这个原则适用于所有开发阶段,尤其是规划和编码时。
减少依赖文件 : 更少的文件意味着更少的http请求与更快的加载时间
降低图片大小: 适应与调整高分辨率图片,在额外的下载时间中占居榜首,占用了宝贵的内存与处理资源。
减轻客户端负担: 最佳实践是重新思考你的javascript,并使之降低到最小尺寸
怎样减少依赖文件
如果你想为移动端用户隐藏图片,display:none与visibility:hidden是不能阻止文件下载的。测试下面的代码:
&div style=&display:&&
&img src=&logo-none.png& /&
&div style=&visibility:&&
&img src=&logo-hidden.png& /&
<div style="display:none;">&&&&<img src="logo-none.png" /></div>&<div style="visibility:hidden;">&&&&<img src="logo-hidden.png" /></div>
你可以观察下面的瀑布图,图片容器设置display: none或visibility: hidden后仍然会被下载。
替代方案是利用css加载背景图片,之后利用media query媒体查询来通过条件隐藏图片。这个技术最初被Jason grigsby测试过,之后被tim kandlec进一步拓展。亚马逊独立的移动端页面使用了此种技术,根据设备来条件加载特定的图片。
&meta name=&viewport& content=&width=device-width&&
@media (max-width:600px) {
@media (min-width:601px) {
background-image: url(image1.jpg);
&div class=&image&&&/div&
12345678910111213141516
<meta name="viewport" content="width=device-width">&<style>&&&&@media (max-width:600px) {&&&&&&&&.image {&&&&&&&&&&&&display:none;&&&&&&&&}&&&&}&&&&@media (min-width:601px) {&&&&&&&&.image {&&&&&&&&&&&&background-image: url(image1.jpg);&&&&&&&&}&&&&}</style>&<div class="image"></div>
你可以看到图片不加载的瀑布图:
保持最小数量的外联样式表
如果你已经根据断点来加载分开的样式表,你需要仔细思考这样的做法了。我们测试了以下的代码:
&link href=&extra-small.css& rel=&stylesheet& media=&screen and (max-width: 390px)& /&
&link href=&small.css& rel=&stylesheet& media=&screen and (min-width: 391px) and (max-width: 500px)& /&
&link href=&medium.css& rel=&stylesheet& media=&screen and (min-width: 501px) and (max-width: 767px)& /&
&link href=&large.css& rel=&stylesheet& media=&screen and (min-width: 768px)& /&
<link href="extra-small.css" rel="stylesheet" media="screen and (max-width: 390px)" /><link href="small.css" rel="stylesheet" media="screen and (min-width: 391px) and (max-width: 500px)" /><link href="medium.css" rel="stylesheet" media="screen and (min-width: 501px) and (max-width: 767px)" /><link href="large.css" rel="stylesheet" media="screen and (min-width: 768px)" />
你可以看到这四个样式表在竖屏下(portrait mode)都被加载了.
因此无论如何这些样式表都会被夹在,你需要把这些文件合并在一个文件里,减少http请求。另一种方法,你可以通过后端处理,通过判断设备来自动插入样式表。 (这种方式在的响应式网站中使用过)。
另一种方案可以使用内部样式。亚马逊独立的移动产品页面有一个6 KB大小的外部样式表,连同一些内部样式。这只需要通过一个额外的HTTP请求来下载所有的页面样式。亚马逊的桌面版本并不是很高效,带有9个外部样式表,总共40 KB。
利用CSS3代替图片
圆角,阴影,渐变填充等,这些样式不需要使用图片,可以减少http请求,加快加载时间。
Css3可以减少http请求,但增加了处理负荷。我们创建了一系列的html文件,每个文件包含一个基本的css3特性。参考下面的图表,你可以发现css3带来的处理时间很小,但不能不考虑。特别注意box-shadow对处理时间的影响最大。
DATAURI来代替图片与WEB字体文件
Data uri方案可以不使用任何额外资源就可以向html及css中插入内容。这个技术可以在web页面中插入任何内容,通常被用于插入图片及web字体文件。这个技术最大的好处是可以减少http请求。
Data uri使用很简单,你可以按照下面的格式,使用base64编码过的数据直接插入html与css中代替图片文件。
data:[MIME-type][;charset=encoding][;base64],[data]
data:[MIME-type][;charset=encoding][;base64],[data]
举个例子,下面的小图标就是用data uri创建的:
代码在这:
&img alt=&& src=&" />
<的响应式网站使用这个技术插入了图片及字体。波士顿环球报的响应式网站也使用了这个技术,他们的网站在智能手机上,四秒内就加载完毕了。
使用这项技术,从此不用为外部图片及字体文件劳心费神。也需要测试与比较是否值得应用这项技术来代替传统方式。
可缩放矢量图形(SVG)而不是图片
就像data URIs,可缩放矢量图形(SVG)可以被嵌入到一个页面来减少HTTP请求数。例如,下面的图片是一个内联SVG:
这是代码:
&svg version=&1.1& id=&drop& x=&0px& y=&0px&
width=&17.812px& height=&28.664px&
viewBox=&296.641 381.688 17.812 28.664&
enable-background=&new 296.641 381.688 17.812 28.664&
xml:space=&preserve&&
&path fill=&#EE1C4E& d=&M314.428,401.082c-0.443-5.489-5.146-9.522-7
.52-14.186c-0.816-1.597-1.352-5.208-1.352-5.208 s-0.555,3.792-1.388
,5.425c-2.233,4.371-7.127,8.999-7.507,14.047c-0.36,4.794,4.101,9.191
,8.896,9.191 C310.49,410.354,314.816,405.941,314.428,401.082z&/&
12345678910
&lt;svg version=&quot;1.1&quot; id=&quot;drop&quot; x=&quot;0px&quot; y=&quot;0px&quot;&& width=&quot;17.812px&quot; height=&quot;28.664px&quot;&& viewBox=&quot;296.641 381.688 17.812 28.664&quot;&& enable-background=&quot;new 296.641 381.688 17.812 28.664&quot; && xml:space=&quot;preserve&quot;&gt;&lt;path fill=&quot;#EE1C4E& d=&M314.428,401.082c-0.443-5.489-5.146-9.522-7.52-14.186c-0.816-1.597-1.352-5.208-1.352-5.208 s-0.555,3.792-1.388,5.425c-2.233,4.371-7.127,8.999-7.507,14.047c-0.36,4.794,4.101,9.191,8.896,9.191 C310.49,410.354,314.816,405.941,314.428,401.082z&quot;/&gt;&lt;/svg&gt;
SVG文件可以通过一个矢量图形编辑器,如Adobe Illustrator创建。一旦创建,在文本编辑器中打开文件并把其代码拷贝出来(减去任何不必要的数据)。
上面的代码在HTML文件中会生效,,但不会在样式表中生效。若在一个样式表中嵌入SVG文件,需要先将它转换为一个数据URI。如果这样做,我们需要从编辑器中(一定要包括元数据)拷贝出,用base64编码,然后使用以下格式嵌入样式表:
data:image/svg+xml[;base64],[data]
data:image/svg+xml[;base64],[data]
这是代码:
background-image:url(data:image/svg+base64,PD94bWwgdmVyc2lvbj0i
MS4wIiBlbmNvZGluZz0idXRmLTgiPz4NCjwhLS0gR2VuZXJhdG9yOiBBZG9iZSBJbGx
1c3RyYXRvciAxNS4xLjAsIFNWRyBFeHBvcnQgUGx1Zy1JbiAuIFNWRyBWZXJzaW9uOi
A2LjAwIEJ1aWxkIDApICAtLT4NCjwhRE9DVFlQRSBzdmcgUFVCTElDICItLy9XM0MvL
0RURCBTVkcgMS4xLy9FTiIgImh0dHA6Ly93d3cudzMub3JnL0dyYXBoaWNzL1NWRy8x
LjEvRFREL3N2ZzExLmR0ZCI+DQo8c3ZnIHZlcnNpb249IjEuMSIgaWQ9IkxheWVyXzE
iIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgeG1sbnM6eGxpbms9Im
h0dHA6Ly93d3cudzMub3JnLzE5OTkveGxpbmsiIHg9IjBweCIgeT0iMHB4Ig0KCSB3a
WR0aD0iMTcuODEycHgiIGhlaWdodD0iMjguNjY0cHgiIHZpZXdCb3g9IjI5Ni42NDEg
MzgxLjY4OCAxNy44MTIgMjguNjY0Ig0KCSBlbmFibGUtYmFja2dyb3VuZD0ibmV3IDI
5Ni42NDEgMzgxLjY4OCAxNy44MTIgMjguNjY0IiB4bWw6c3BhY2U9InByZXNlcnZlIj
4NCjxwYXRoIGZpbGw9IiNFRTFDNEUiIGQ9Ik0zMTQuNDI4LDQwMS4wODJjLTAuNDQzL
TUuNDg5LTUuMTQ2LTkuNTIyLTcuNTItMTQuMTg2Yy0wLjgxNi0xLjU5Ny0xLjM1Mi01
LjIwOC0xLjM1Mi01LjIwOA0KCXMtMC41NTUsMy43OTItMS4zODgsNS40MjVjLTIuMjM
zLDQuMzcxLTcuMTI3LDguOTk5LTcuNTA3LDE0LjA0N2MtMC4zNiw0Ljc5NCw0LjEwMS
w5LjE5MSw4Ljg5Niw5LjE5MQ0KCUMzMTAuNDksNDEwLjM1NCwzMTQuODE2LDQwNS45N
DEsMzE0LjQyOCw0MDEuMDgyeiIvPg0KPC9zdmc+DQo=);
1234567891011121314151617
background-image:url();
Sprites(雪碧图)技术可以把经常使用的图片合成为一张图片,从而减少http请求。比如当你将四张图片合成到一个sprite中后,http请求从4减少到1.需要显示的图片利用background-position属性来控制。
字体图标是利用字体文件来包含符号和图表(如Wingdings或Webdings 都是某种图标字体),可以用来代替加载一个图像文件。例如,下面的图标不是一个图像,而是Wingdings字体中的“h”字符:
Wingdings和Webdings有点过气了,现在有其他更专业的Web字体可用的,可以通过font-face加载。
单独的Web字体,对于所有图标来讲,HTTP请求的数量可以减少到一个。如果Web字体使用数据URI(如上所述)嵌入页面,HTTP请求可以减少到零。这正是使用的技术。这是他们样式表中嵌入的web 字体:
<访问所有这些图标,不会有任何额外的HTTP请求,因为图标通过数据URI,以Web字体的方式嵌入到WordPress的样式表中。
同时,字体图标可以使用CSS3关键帧动画(这很有用,比如“加载”图标(小菊花))。  主要的缺点是,字体图标做成的CSS sprites只能是某个纯色。亚马逊的css雪碧图包括彩色图标,因此它不能使用这种技术。
如IcoMoon之类的工具可以很方便的建立一个自定义Web字体。所需要的只是每个图标的SVG文件。
避免内联iframe
每一个内联框架(iframe)都会生成一个HTTP请求,这是在iframe内没有另外依赖资源的情况下。这是我们做一个快速测试,比较一个iframe只含有文本。
包含一个iframe增加了将近0.2s的加载时间。为了保证web站点加载迅速,最好不要使用iframe。
移动先行也适用于前端开发。
编码时以移动用户作为第一考虑,然后为平板电脑和桌面逐步增强,减少不必要的依赖。另外一种方式为桌面端优先,重型组件默认加载,然后为小屏幕隐藏这些组件(称为“优雅降级”)。
下面例子为桌面端优先的编码:
background-image: url(image1.jpg);
@media (max-width:390px) {
&div class=&image&&&/div&
12345678910111213
&lt;style&gt;&&&&.image {&&&&&&&&background-image: url(image1.jpg);&&&&}&&&&&@media (max-width:390px) {&&&&&&&&.image {&&&&&&&&&&&&display: none;&&&&&&&&}&&&&}&lt;/style&gt;&&lt;div class=&quot;image&quot;&gt;&lt;/div&gt;
在上面的代码中,默认是显示图像,然后在移动设备上通过媒体查询隐藏了图片。
下面的例子为移动端优先的编码:
@media (min-width:391px) {
background-image: url(image1.jpg);
&div class=&image&&&/div&
&lt;style&gt;&&&&@media (min-width:391px) {&&&&&&&&.image {&&&&&&&&&&&&background-image: url(image1.jpg);&&&&&&&&}&&&&}&lt;/style&gt;&&lt;div class=&quot;image&quot;&gt;&lt;/div&gt;
默认情况下,图片不显示,之后使用媒体查询对更大的屏幕进行渐进增强。
拆分到多个页面(单独的移动网站)
保持你的核心内容在页面上,之后提供到次要内容的链接到次要内容。这将减少HTML的加载负担,同时防止相关的资源被下载。
亚马逊的移动产品页面有通用的产品信息,同时提供链接到“用户评论”、“描述和细节”和“新&使用提供。
这就减少了三张图片的HTTP请求,且HTML的大小减少45 KB。
保持最少重定向(单独的移动网站)
亚马逊有一个重定向,来引导游客到单独的移动页面,这带来了0.4秒的延迟。与之相比,戴尔的网站有两个重定向,带来了1.2秒延迟。
如何缩小图片尺寸
响应式图片
响应式图片的思路是让访客图像只下载那些最适合他们的设备的图片,对于智能手机,使用低分辨率图像,可以快速下载和渲染。
亚马逊的独立的移动产品页面使用响应式图像技术,利用媒体查询分配一个特定的背景图像到一个div。这是亚马逊的代码:
&!-- // This meta viewport is inserted for iPhones // --&
&meta name=&viewport& content=&width=device-width,user-scalable=no,initial-scale=1.0,maximum-scale=1.0&&
&!-- // This meta viewport is inserted for the Nexus S // --&
&meta name=&viewport& content=&width=device-width&&
@media (max-width:390px) {
#image-container {
max-width: 109
background-image: url(image1.jpg);
@media (max-width:390px) and (-webkit-min-device-pixel-ratio:1.5) {
background-image: url(image2.jpg);
@media (max-width:390px) and (-webkit-min-device-pixel-ratio:2) {
background-image: url(image3.jpg);
@media (min-width:391px) and (max-width:500px) {
#image-container {
max-width: 121
background-image: url(image4.jpg);
@media (min-width:391px) and (max-width:500px) and (-webkit-min-device-pixel-ratio:1.5) {
background-image: url(image5.jpg);
@media (min-width:391px) and (max-width:500px) and (-webkit-min-device-pixel-ratio:2) {
background-image: url(image6.jpg);
@media (min-width: 501px) and (max-width: 767px) {
#image-container {
max-width: 182
background-image: url(image5.jpg);
@media (min-width: 501px) and (max-width: 767px) and (-webkit-min-device-pixel-ratio:1.5) {
background-image: url(image7.jpg);
@media (min-width: 501px) and (max-width: 767px) and (-webkit-min-device-pixel-ratio:2) {
background-image: url(image8.jpg);
@media (min-width:768px) {
#image-container {
max-width: 303
background-image: url(image8.jpg);
@media (min-width:768px) and (-webkit-min-device-pixel-ratio:1.5) {
background-image: url(image8.jpg);
@media (min-width:768px) and (-webkit-min-device-pixel-ratio:2) {
background-image: url(image8.jpg);
&div id=&image-container&&
&div class=&image&&
&img src=&image1.jpg& /&
1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586
&lt;!-- // This meta viewport is inserted for iPhones // --&&lt;meta name=&quot;viewport&quot; content=&quot;width=device-width,user-scalable=no,initial-scale=1.0,maximum-scale=1.0&quot;&gt;&&lt;!-- // This meta viewport is inserted for the Nexus S // --&&lt;meta name=&quot;viewport&quot; content=&quot;width=device-width&quot;&gt;&&lt;style&gt;&&&&@media (max-width:390px) {&&&&&&&&#image-container {&&&&&&&&&&&&max-width: 109px;&&&&&&&&}&&&&&&&&.image {&&&&&&&&&&&&background-image: url(image1.jpg);&&&&&&&&}&&&&}&&&&@media (max-width:390px) and (-webkit-min-device-pixel-ratio:1.5) {&&&&&&&&.image {&&&&&&&&&&&&background-image: url(image2.jpg);&&&&&&&&}&&&&}&&&&@media (max-width:390px) and (-webkit-min-device-pixel-ratio:2) {&&&&&&&&.image {&&&&&&&&&&&&background-image: url(image3.jpg);&&&&&&&&}&&&&}&&&&@media (min-width:391px) and (max-width:500px) {&&&&&&&&#image-container {&&&&&&&&&&&&max-width: 121px;&&&&&&&&}&&&&&&&&.image {&&&&&&&&&&&&background-image: url(image4.jpg);&&&&&&&&}&&&&}&&&&@media (min-width:391px) and (max-width:500px) and (-webkit-min-device-pixel-ratio:1.5) {&&&&&&&&.image {&&&&&&&&&&&&background-image: url(image5.jpg);&&&&&&&&}&&&&}&&&&@media (min-width:391px) and (max-width:500px) and (-webkit-min-device-pixel-ratio:2) {&&&&&&&&.image {&&&&&&&&&&&&background-image: url(image6.jpg);&&&&&&&&}&&&&}&&&&@media (min-width: 501px) and (max-width: 767px) {&&&&&&&&#image-container {&&&&&&&&&&&&max-width: 182px;&&&&&&&&}&&&&&&&&.image {&&&&&&&&&&&&background-image: url(image5.jpg);&&&&&&&&}&&&&}&&&&@media (min-width: 501px) and (max-width: 767px) and (-webkit-min-device-pixel-ratio:1.5) {&&&&&&&&.image {&&&&&&&&&&&&background-image: url(image7.jpg);&&&&&&&&}&&&&}&&&&@media (min-width: 501px) and (max-width: 767px) and (-webkit-min-device-pixel-ratio:2) {&&&&&&&&.image {&&&&&&&&&&&&background-image: url(image8.jpg);&&&&&&&&}&&&&}&&&&@media (min-width:768px) {&&&&&&&&#image-container {&&&&&&&&&&&&max-width: 303px;&&&&&&&&}&&&&&&&&.image {&&&&&&&&&&&&background-image: url(image8.jpg);&&&&&&&&}&&&&}&&&&@media (min-width:768px) and (-webkit-min-device-pixel-ratio:1.5) {&&&&&&&&.image {&&&&&&&&&&&&background-image: url(image8.jpg);&&&&&&&&}&&&&}&&&&@media (min-width:768px) and (-webkit-min-device-pixel-ratio:2) {&&&&&&&&.image {&&&&&&&&&&&&background-image: url(image8.jpg);&&&&&&&&}&&&&}&lt;/style&gt;&&lt;div id=&quot;image-container&quot;&gt;&&&&&lt;div class=&quot;image&quot;&gt;&&&&&&&&&lt;img src=&quot;image1.jpg&quot; /&gt;&&&&&lt;/div&gt;&lt;/div&gt;
尽管亚马逊在内部样式中有八个产品图片,在竖屏模式下的iPhone 4或Nexus S只有两个被下载。
《波士顿环球报》的响应式网站,采用了利用不同的data-fullsrc来加载图片的响应式图像技术。这是一个html标记,和一个服务器端JavaScript重定向规则的组合:
&img alt=&& src=&mobile-size.r.jpg& data-fullsrc=&desktop-size.jpg& /&
&lt;img alt=&quot;&quot; src=&quot;mobile-size.r.jpg&quot; data-fullsrc=&quot;desktop-size.jpg&quot; /&gt;
src是手机上使用的图像,确保网站默认为尺寸较小的版本(移动先行),而data-fullsrc是全尺寸的图像。JavaScript用来检测设备的屏幕大小,之后写入cookie。对于大屏幕,JavaScript利用data-fullsrc上的高分辨率图像替换较小的图片。服务器也使用Apache重写规则,来在图像文件的名称中检查.r.(mobile用的图片带有.r.),同时显示一个备用GIF,而不会使用较小的移动图像(从而防止手机大小的图像被下载到桌面)。
微软的响应式网站使用的斯科特·杰尔的Picturefill技术:
&div data-picture data-alt=&Alternate text here&&
&div data-src=&image1.png&&&/div&
&div data-src=&image2.png& data-media=&(min-device-pixel-ratio: 2.0)&&&/div&
&div data-src=&image3.png& data-media=&(max-width: 539px)&&&/div&
&div data-src=&image4.png& data-media=&(max-width: 539px) and (min-device-pixel-ratio: 2.0)&&&/div&
&noscript&&img src=&image1.png& alt=&Alternate text here& /&&/noscript&
&lt;div data-picture data-alt=&quot;Alternate text here&quot;&gt;&&&&&lt;div data-src=&quot;image1.png&quot;&gt;&lt;/div&gt;&&&&&lt;div data-src=&quot;image2.png&quot; data-media=&quot;(min-device-pixel-ratio: 2.0)&quot;&gt;&lt;/div&gt;&&&&&lt;div data-src=&quot;image3.png&quot; data-media=&quot;(max-width: 539px)&quot;&gt;&lt;/div&gt;&&&&&lt;div data-src=&quot;image4.png&quot; data-media=&quot;(max-width: 539px) and (min-device-pixel-ratio: 2.0)&quot;&gt;&lt;/div&gt;&&&&&&lt;noscript&gt;&lt;img src=&quot;image1.png&quot; alt=&quot;Alternate text here&quot; /&gt;&lt;/noscript&gt;&lt;/div&gt;
注意:上面的代码片段中, data-picture= " "应该是 data-picture,没有= &#8221; &#8220;。(=字符是smashing magazine的所见即所得编辑器自动插入的)。利用这种技术,JavaScript扫描页面的代码,发现包含data-picture属性的div。然后根据data-media属性插入一个新的img标签。
这些响应式图像技术的主要好处有:
小屏幕下载低分辨率的图像,而大屏幕下载高分辨率图像;
只下载所需的图片,而不需要的图片不在后台加载。
有各种各样的其他技术实现响应式图像。你可以查看这些资源,了解更多的细节:
如何减少客户端处理
让JAVASCRIPT降到最低
星巴克的响应式网站在chrome下禁用javascript后,桌面端良好的网络环境下花费了3.53秒加载完毕,而启用javascript后,花费了4.73秒,增加了34%。Javascript对加载时间的影响,在移动端较小的内存,cpu及缓存下会表现得更明显。通常,我们要重新思考javascript的使用,并保持其在最小尺寸。
一个很好的例子是BBC移动网站的JavaScript。网站不使用外部JavaScript文件——都是内联。内联脚本仅限于几行,没有显著影响内存,HTML文件和所有内联JavaScript花费0.78秒加载完毕。就像BBC那样,亚马逊的移动产品页面也没有外部JavaScript文件,而使用最少的内联脚本。HTML文件和所有内联JavaScript花费0.75秒加载完毕。
(请注意,jQuery不是一个轻量的替代方案,事实上是jquery本身的补充。)这两个网站在iPhone 4下均在4秒内加载完毕。使用一个JavaScript框架前,考虑它是否真的有必要。在某些情况下,使用少量的JavaScript比调用一个框架更有效。
组件对实际加载时间的影响是灾难性的。为了验证这一点,我们创建了一系列简单的HTML文件,每个文件包含默认的嵌入代码,一个小部件。你可以看到下面的结果多糟糕。注意,这不是一个完美的测试,因为这些都是在模拟环境中的可控实验,不过结果比较有意思。
在单个页面中,结合他们为一个小部件,结果只包含这个部件的情况下,加载时间长达4秒。
服务器端(后端)技术
除了优化前端,服务器端技术也可以用来加速加载时间。这些技术都值得考虑,但不会在本文中介绍:
缓存HTTP重定向来加速重复访问;
合并HTTP重定向链来减少重定向;
使用HTTP压缩来减少数量的字节(Gzip或缩小)。
测试移动设备上的性能
由于移动设备的不可预知性,测试多个设备上的性能是很重要的。这里有一些免费的性能测试工具:
Mobitest,Akamai:可以对对iPhone 4的 iOS 5.0,iPhone 3 g和Nexus S 生成瀑布图和HAR文件 .注意Nexus S测试结果与我们自己的内部测试不一致。我们的服务器访问日志显示,当我们测试实际安卓2。x设备时产生了更少的HTTP请求。
“Network Panel,” Chrome Developer Tools
为了满足移动用户的高期望,你需要对网站针对移动设备进行优化,在4秒或更少的时间里加载完毕。最好的方式来达到4秒这个魔术时间,是通过减少JavaScript和优化HTML、CSS和图像,保持智能手机上最少的处理负荷。
使用上面介绍的技术,你就可以自己建立一个符合潮流的移动互联网体验!你有什么要补充的吗?在评论中让我们知道。
可能感兴趣的话题
388 行:夹在,应该为加载
艾马,无意冒犯,很感谢这篇文章,获益良多
关于伯乐在线博客
在这个信息爆炸的时代,人们已然被大量、快速并且简短的信息所包围。然而,我们相信:过多“快餐”式的阅读只会令人“虚胖”,缺乏实质的内涵。伯乐在线内容团队正试图以我们微薄的力量,把优秀的原创文章和译文分享给读者,为“快餐”添加一些“营养”元素。
新浪微博:
推荐微信号
(加好友请注明来意)
&#8211; 好的话题、有启发的回复、值得信赖的圈子
&#8211; 分享和发现有价值的内容与观点
&#8211; 为IT单身男女服务的征婚传播平台
&#8211; 优秀的工具资源导航
&#8211; 翻译传播优秀的外文文章
&#8211; 国内外的精选文章
&#8211; UI,网页,交互和用户体验
&#8211; 专注iOS技术分享
&#8211; 专注Android技术分享
&#8211; JavaScript, HTML5, CSS
&#8211; 专注Java技术分享
&#8211; 专注Python技术分享
& 2016 伯乐在线}

我要回帖

更多关于 笔记本用手机热点上网 的文章

更多推荐

版权声明:文章内容来源于网络,版权归原作者所有,如有侵权请点击这里与我们联系,我们将及时删除。

点击添加站长微信