【第22期】观点:IT 行业加班,到底有没有价值?

受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文件。
举报

相关文章推荐

css样式加载顺序和覆盖顺序

查找一些教材中(w3schools等),只说css的顺序是“元素上的style” > “文件头上的style元素” >“外部样式文件”,但对于样式文件中的多个相同样式的优先级怎样排列,没有详细说明。经...

CSS样式的加载

1.样式的加载方法 行内样式 html内容和样式同时加载 e.g h1 style="color:red;font-size:20px;">行内样式 嵌入样式 html内容和...

程序员升职加薪指南!还缺一个“证”!

CSDN出品,立即查看!

ssm遇到css样式和js加载不出来

今天在写项目的时候遇到一个问题就是css样式和js样式出不来,昨天还能出来,检查了路径什么的都没有错。 在网上也百度了 大部分都说路径错了,可是路径明明就是对的。最后发现是 原来写的是*.do  ...

ios加载本地html,css样式失效问题

项目中需要加载本地的html,在添加到工程中时,发现不显示本地的资源图片文件,而且样式也跟浏览器打开的不一样。初步判断是资源路径读取的问题。 鉴于iOS沙盒机制的问题,这些资源文件在编译过程中,...

.net动态加载CSS样式表方法总结

方法一:利用Page类写入 WebForm1  protected void Page_Load(object sender, EventArgs e) {  ...

根据不同浏览器加载不同css文件

通过判断浏览器类型而加载不同的css样式   如果你读了这篇文章,你会觉得IE浏览器很是让人头疼。但是如果你是一名优秀的前端开发人员的话,你必须得解决这个问题,我...

iOS加载本地html,css样式失效问题

文件拖入项目的时候选的 这样的话,文件在编译成 ipa 的时候。文件会拷贝到根目录下。而代码中是这样写的, NSString *filePath = [[NSBundle mainBund...

CSS样式问题解决《一》

1、问题一:一个DIV如何在父级DIV中上下居中?这里想讲解的是Postion这个样式。 如果我们用position:absolute;top:50%;margin-top:-n px;这时会导致D...

样式表不起作用,CSS文件无法加载

有的时候,我们辛辛苦苦写完的样式表,在浏览器下测试的时候也很好,但是偶然间拿到某个浏览器,发现部分样式表不起作用,检查CSS代码也并未发现什么错误,甚是让人郁闷。其实这种情况也无外乎一下几种原因,逐个...

JS A页面跳转B页面后,B页面样式全部失效

页面跳转是最平常不过得操作。我比较常用的是loaction.href=”XXX.html”,但是从A页面跳转到B页面之后,B页面的样式全都乱掉了。如果你也遇到了这样的情况,希望从 以下几个方面去排查。...
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

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