css sprite是什么,有什么优缺点
概念:
将多个小图片拼接到一个图片中。通过background-position和元素尺寸调节需要显示的背景图案。
优点:
1、减少HTTP请求数,极大地提高页面加载速度
新版,
2增加图片信息重复度,提高压缩比,减少图片大小
3、更换风格方便,只需在一张或几张图片上修改颜色或样式即可实现
缺点:
图片合并麻烦
编程: 得取少
维护麻烦,修改一个图片可能需要从新布局整个图片,样式
display: none;与visibility: hidden;的区别
联系:它们都能让元素不可见
区别:
1、display:none;会让元素完全从渲染树中消失,渲染的时候不占据任何空间;visibility: hidden;不会让元素从渲染树消失,渲染师元素继续占据空间,只是内容不可见
2.display: none;是非继承属性,子孙节点消失由于元素从渲染树消失造成,通过修改子孙节点属性无法显示; visibility: hidden;是继承属性,子孙节点消失由于继承了hidden,通过设置visibility: visible;可以让子孙节点显式
3修改常规流中元素的 display通常会造成文档重排。修改visibility属性只会造成本元素的重绘。
4、读屏器不会读取display; none;元素内容;会读取visibility: hidden;元素内容
link 与@import的区别
1 link 是HTML方式, @import是 CSS方式
2、link 最大限度支持并行下载,@import过多嵌套导致串行下载,出现FOUC
3、-link可以通过rel="alternate stylesheet"指定候选样式
4、浏览器对link支持早于@import,可以使用@import对老浏览器隐藏样式
5、@import必须在样式规则之前,可以在css文件中引用其他文件
6、总体来说: link 优于@import