受css内嵌样式中使用 url 影响,页面出现多次加载问题

转载 2015年11月18日 16:45:40

页面内嵌样式表中使用url(), 出现页面多次载入问题解决

来源:互联网 作者:佚名 时间:11-20 08:44:40   
在最近的一个项目中,为了跟踪用户的登录的次数,我们在页面打开时,将用户登录页面的信息进行记录,可在测试中却发现一个用户访问一次的页面,却被记录了二次,也就是说页面被载入了二次。
在最近的一个项目中,为了跟踪用户的登录的次数,我们在页面打开时,将用户登录页面的信息进行记录。可在测试中却发现一个用户访问一次的页面,却被记录了二次,也就是说页面被载入了二次。进一步测试后发现此问题,只是在FireFox,Google Chrome浏览器上才会出现。通过使用Fiddler监控发现,页面在很短的时间内被浏览器载入了二次。 
发生如此离奇的问题,让我们百思不得其解。因为在页面中,并不存在通过Javascript来触发页面刷新;也不存在页面的特殊设置,让页面自动进行定时的刷新功能。不得已,只能采用笨方法,将页面中的内容一点点的删除掉,最后发现当页面内嵌的样式存在时,页面就会被重复载入。样式如下: 

复制代码
代码如下:

<style type="text/css"> 
content-wrap .wrap-main{background:url();} 
content-wrap .wrap-main .colcomm .more{} 
tem-main .left .col,.tem-main .left-3 .col,.tem-main .right-3 .col{margin-bottom:5px} 
</style> 

在样式表中,为了将来自样式文件中的.wrap-main的背景图片给忽略掉,这里采用了在页面文件中再次定义了.wrap-main的背景图片,所以就出现了样式表中第一行出现的 

content-wrap .wrap-main{background:url();} 
通过分析认为,页面的二次加载的问题,很可能会与该处的样式设置有关,于是将样式修改为等价的: 

content-wrap .wrap-main{background-image:none;} 
再次运行页面,并通过Fiddler进行跟踪,这次页面只加载了一次。看来问题确实是由于在页面的内嵌样式中错误地使用了url()引起的。

针对这个问题,我进一步进行了分析,得到如下结论: 
1)在页面内嵌的样式表中,如果出现url()或url("")之类的,FireFox、Google Chrome浏览器会将url()或url("")解析为当前页面的地址,所以会再次请求同一个页面,这样就出现了同一个页面被载入二次的问题。因此,如果要在内嵌样式表中实现诸如取消背景图片的样式时,可以采用background-image:none而不要采用background:url(). 
2)在.CSS文件中是的样式,如果出现url()或url(""),同样会导致.CSS文件被加载二次的问题。只是由于.CSS文件常常会在本地有缓存,所以当发现文件没有修改时就不会再次请求同一个.CSS文件。

相关文章推荐

页面加载顺序问题,影响视觉效果,使用loading解决。

静态页面,作为背景的图标先显示,文字后显示。根本原因是:(加载顺序) head标签里(link标签-css文件)-> body里的内容 -> src的script文件 ->页面中写入的js。这里就解释...

通过jquery load在list页面多次加载详情页,导致的多form校验以及提交问题

jquery 多次load进来的同一个页面,多form校验,提交

如何处理页面多次加载的问题

工作中需要读取一个网页的内容,貌似很简单,但总也读不到完整的内容。经过页面分析,原来该页面的部分内容是通过调用js来获取的。再一看被调用的js文件,相当复杂,立刻让我打起了退堂鼓。。。 为了省点事,加...

解决HTML加载时,外部js文件引用较多,影响页面打开速度问题

前言    通常HTML文件在浏览器中加载时,浏览器都会按照元素在页面中出现的先后顺序,对它们依次加载,一旦加载的js文件数量过多,就会导致页面展示延迟。那么,在开发的过程中,改怎么解决呢?   ...

PHP 加载一次页面时, 浏览器请求多次, 导致出错

问题描述: 在一个项目中, 有一段统计页面浏览次数的代码, 其实现的方式是, 每次页面加载, 就 UPDATE SET 一次, 给数据表中对应的值加一. 碰到的一个问题是, 刷新页面时...

Android中WebView加载Url时出现域名连接重定向时返回控制死循环的问题

Bug时时有,今天特别多。 你们有试过加载WebView由于H5 CSS样式中有特殊属性“minimal-ui”无法识别加载不出来的情况么,你们有过在解决完一个问题之后又出来内外一个问题的时候...

WebView 重定向行为导致的多次加载问题

使用 WebView 时,我们通常会重写以下方法: shouldOverrideUrlLoading() onPageStarted() onPageFinished()WebView ...

Python 被导入模块多次被加载的问题(基于python的import机制)

今天遇到了一个问题,我一个被导入模块的代码被执行了两次。一直听说python的module中的变量可以做单例的,怎么会执行多次呢。查看了一下 引用这个module的代码后发现,我两处的引用代码写的不太...

Android listview&gridview getview 方法多次调用问题解决方法 并附上单页加载实现问卷调查适配器源代码

一 、 关于listview 的问题     (1)情况一:      今天在改毕设代码的时候,突然发现一个奇怪的现象,就是在在定义的listview中有一个imageview和一个textvie...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

(最多只允许输入30个字)