假设我的CSS看起来像这样:
#element {background-image: url("image1.png");}
#element {background-image: url("image2.png");}
浏览器:
答案 0 :(得分:3)
首先解析CSS,然后请求图像,因此不会下载image1.png
答案 1 :(得分:1)
使用Chrome和Developer Tools进行的一些快速测试:
#element
不存在则不下载任何图片,因为浏览器没有匹配的元素来应用样式#element
,则会应用通常的CSS级联和特异性规则,并且只会下载image2.png
,因为该规则在 image1.png
规则后出现。也就是说,其他浏览器可能表现不同。
答案 2 :(得分:0)
如果您在Chrome中实现运行此网站的网站,您可以看到浏览器首先解析CSS,创建规则&请求它然后发出请求。
在CSS底部的CSS规则覆盖顶部的任何内容,因此浏览器知道只请求最终规则的图像。
答案 3 :(得分:-1)
当您第一次请求页面时,您的浏览器会向服务器发送isquest,如您所知。然后浏览器开始解析页面。
当它找到对外部资源的引用时,它将再次请求该资源。所以我认为它仍会加载它。