页面内嵌样式表中使用url(), 出现页面多次载入
建站知识 2021-07-03 08:43www.168986.cn长沙网站建设
在最近的一个项目中,为了跟踪用户的登录的次数,我们在页面打开时,将用户登录页面的信息进行记录。可在测试中却发现一个用户访问一次的页面,却被记录了二次,也就是说页面被载入了二次。进一步测试后发现此问题,只是在FireFox,Google Chrome浏览器上才会出现。通过使用Fiddler监控发现,页面在很短的时间内被浏览器载入了二次。
发生如此离奇的问题,让我们百思不得其解。因为在页面中,并不存在通过Javascript来触发页面刷新;也不存在页面的特殊设置,让页面自动进行定时的刷新功能。不得已,只能采用笨方法,将页面中的内容一点点的删除掉,发现当页面内嵌的样式存在时,页面就会被重复载入。样式如下
<style type="text/css">
content-wrap .wrap-main{background:url();}
content-wrap .wrap-main .colm .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文件。
发生如此离奇的问题,让我们百思不得其解。因为在页面中,并不存在通过Javascript来触发页面刷新;也不存在页面的特殊设置,让页面自动进行定时的刷新功能。不得已,只能采用笨方法,将页面中的内容一点点的删除掉,发现当页面内嵌的样式存在时,页面就会被重复载入。样式如下
复制代码
代码如下:<style type="text/css">
content-wrap .wrap-main{background:url();}
content-wrap .wrap-main .colm .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文件。
长沙网站设计
- 如何自己建一个网站 自己想建个网站,怎么建
- 如何制作网站免费建站 创建网站免费注册
- html简单网页代码 html简单网页代码超链接
- dreamweaver网页制作 dreamweaver网页制作模板
- 上海网站建设 上海网站建设制作微信
- 如何制作网站和网页 如何制作一个网页
- html网页制作代码大全 端午节html网页制作代码大
- app开发公司 app开发公司前十名
- html网页制作 html网页制作文字居中
- app制作一个需要多少钱 请人制作一个app多少钱
- 成都网站制作 成都网站制作维护
- 百度建一个网站多少钱 百度做个公司网站要多少
- html+css网页制作成品 web网页制作成品css+javascrip
- html网页制作案例 html网页设计案例
- html+css网页制作成品 web网页制作成品css+javascrip
- 个人网站模板 个人网站模板HTML