美文网首页我爱编程
CSS 基础知识点

CSS 基础知识点

作者: 时光慢慢些 | 来源:发表于2017-05-16 21:59 被阅读86次

    介绍一下标准的CSS的盒子模型?与低版本IE的盒子模型有什么不同的?

    CSS盒子模型:由四个属性组成的外边距(margin)、内边距(padding)、边界(border)、内容区(width和height);

    标准的CSS盒子模型和低端IE CSS盒子模型不同:宽高不一样

    标准的css盒子模型宽高就是内容区宽高;

    IE低于版本8的浏览器 css盒子模型宽高 内边距﹢边界﹢内容区;

    CSS选择符有哪些?哪些属性可以继承?

    CSS 选择符:

    1.  id选择器(# myid)
      
    2.  类选择器(.myclassname)
      
    3.  标签选择器(div, h1, p)
      
    4.  相邻选择器(h1 + p)
      
    5.  子选择器(ul > li)
      
    6.  后代选择器(li a)
      
    7.  通配符选择器( * )
      
    8.  属性选择器(a[rel = "external"])
      
    9.  伪类选择器(a: hover, li:nth-child)
      

    可继承的样式:

    1.  font-size
      
    2.  font-family
      
    3.  color
      
    4.  text-indent
      

    不可继承的样式:

    1.  border
      
    2.  padding
      
    3.  margin
      
    4.  width
      
    5.  height
      

    CSS优先级算法如何计算?

    1.  优先级就近原则,同权重情况下样式定义最近者为准;
      
    2.  载入样式以最后载入的定位为准;
      
    3.  3.!important >  id > class > tag  
      
    4.  important 比 内联优先级高,但内联比 id 要高
      

    CSS3新增伪类有那些?

    1.  p:first-of-type  选择属于其父元素的首个 p 元素的每个 p 元素。
      
    2.  p:last-of-type   选择属于其父元素的最后p 元素的每个p 元素。
      
    3.  p:only-of-type  选择属于其父元素唯一的p 元素的每个p 元素。
      
    4.  p:only-child     选择属于其父元素的唯一子元素的每个 p元素。
      
    5.  p:nth-child(2)  选择属于其父元素的第二个子元素的每个 p 元素。
      
    6.  :enabled :disabled 控制表单控件的禁用状态。
      
    7.  :checked         单选框或复选框被选中。
      

    CSS3有哪些新特性?

    1. CSS3实现圆角(border-radius)
    2. 阴影(box-shadow)
    3. 对文字加特效(text-shadow、Word-wrap & Text-overflow ),
    4. 线性渐变(gradient)
    5. transform:rotate(9deg) scale(0.85,0.90) translate(0px,-30px) > skew(-9deg,0deg);// 旋转,缩放,定位,倾斜
    6. 增加了更多的CSS选择器 多背景 rgba
    7. 在CSS3中唯一引入的伪元素是 ::selection.
    8. 媒体查询 media,
    9. 多栏布局 -webkit-column-count: 3;
      -webkit-column-rule: 1px solid #bbb;
      -webkit-column-gap: 2em;
    10. border-image

    如何居中div?如何居中一个浮动元素?如何让绝对定位的div居中?

    1、块状元素水平居中:

    margin-left=auto;margin-right=auto;

    2、浮动块状元素水平居中:

    外包装块“float:left;position:relative;left:50%”;

    内部块“float:left;position:relative;right:50%”

    3、内容居中:

    内联元素:text-align:center;vertical-align:middle

    块状元素:

    display:table-cell;vertical-align:middle;

    若是单行内容:line-height=height

    4、绝对定位元素垂直水平居中:

    方法1:

    .element {

    width: 600px; height: 400px;

    position: absolute; left: 50%; top: 50%;

    margin-top: -200px; /* 高度的一半 */

    margin-left: -300px; /* 宽度的一半 */

    }

    但这种方法优点是兼容性较好,缺点是需要提前知道元素的尺寸,否则margin负值的调整无法精确。此时,往往要借助JS获得。

    方法2:使用[CSS3]

    CSS3的兴起,使得有了更好的解决方法,就是使用transform代替margin. transform中translate偏移的百分比值是相对于自身大小的,无需提前知道元素尺寸,其都是水平垂直居中显示的。但此方法兼容性不好。

    .element {

    width: 600px; height: 400px;

    position: absolute; left: 50%; top: 50%;

    transform: translate(-50%, -50%); /* 第一个50%为width的一半,第二个50%为height的一半 */

    }

    方法3:上下左右均0位置定位+“margin: auto”(推荐做法!)

    .element {

    width: 600px; height: 400px;

    position: absolute; left: 0; top: 0; right: 0; bottom: 0;

    margin: auto; /* 水平和垂直都居中 */

    }

    若只设置“margin-left:auto”+“margin-right:auto”,则仅水平居中;

    若只设置“margin-top:auto”+“margin-bottom:auto”,则仅垂直居中;
    display有哪些值?说明他们的作用。

    position的值relative和absolute定位原点是?

    1,relative([相对定位])的定位原点是以自己本省原来所在位置做为原点的。
    2,absolute([绝对定位])的定位原点是离自己这一级元素最近的一级position设置为absolute或者relative的父元素的左上角为原点的,(当然,如果自己的所有父元素都没有设置position,那么就以body为定位原点)
    3,static默认值。没有定位,元素出现在正常的流中
    4,inherit 规定从父元素继承 position 属性的值。
    5,fixed 生成绝对定位的元素,相对于浏览器窗口进行定位。

    请解释一下CSS3的Flexbox(弹性盒布局模型),以及适用场景?

    用纯CSS创建一个三角形的原理是什么?

    1. 使用border的均分原理
    2. 设置不显示的边为透明
    3. 根据需要进行旋转

    经常遇到的浏览器的兼容性有哪些?原因,解决方法是什么,常用hack的技巧 ?

    • png24位的图片在iE6浏览器上出现背景,解决方案是做成PNG8.

    • 浏览器默认的margin和padding不同。解决方案是加一个全局的*{margin:0;padding:0;}来统一。

    IE6双边距bug:块属性标签float后,又有横行的margin情况下,在ie6显示margin比设置的大。

    浮动ie产生的双倍距离 #box{ float:left; width:10px; margin:0 0 0 100px;}

    这种情况之下IE会产生20px的距离,解决方案是在float的标签样式控制中加入 ——display:inline;将其转化为行内属性。(这个符号只有ie6会识别)

    渐进识别的方式,从总体中逐渐排除局部。

    首先,巧妙的使用“\9”这一标记,将IE游览器从所有情况中分离出来。
    接着,再次使用“+”将IE8和IE7、IE6分离开来,这样IE8已经独立识别。

    css
    .bb{
    background-color:#f1ee18;/所有识别/
    .background-color:#00deff\9; /IE6、7、8识别/
    +background-color:#a200ff;/IE6、7识别/
    _background-color:#1e0bd1;/IE6识别/
    }

    • IE下,可以使用获取常规属性的方法来获取自定义属性,
      也可以使用getAttribute()获取自定义属性;
      Firefox下,只能使用getAttribute()获取自定义属性。
      解决方法:统一通过getAttribute()获取自定义属性。

    • IE下,even对象有x,y属性,但是没有pageX,pageY属性;
      Firefox下,event对象有pageX,pageY属性,但是没有x,y属性。

    • 解决方法:(条件注释)缺点是在IE浏览器下可能会增加额外的HTTP请求数。

    • Chrome 中文界面下默认会将小于 12px 的文本强制按照 12px 显示,
      可通过加入 CSS 属性 -webkit-text-size-adjust: none; 解决。

    • 超链接访问过后hover样式就不出现了 被点击访问过的超链接样式不在具有hover和active了解决方法是改变CSS属性的排列顺序:
      L-V-H-A : a:link {} a:visited {} a:hover {} a:active {}

    li与li之间有看不见的空白间隔是什么原因引起的?有什么解决办法?
    行框的排列会受到中间空白(回车\空格)等的影响,因为空格也属于字符,这些空白也会被应用样式,占据空间,所以会有间隔,
    解决方案

    1. 把字符大小设为0,就没有空格了。
    2. 将结束尖括号和开个li的开始尖括号写一起 li><li
    3. 使用注释符来衔接

    为什么要初始化CSS样式。

    • 因为浏览器的兼容问题,不同浏览器对有些标签的默认值是不同的,如果没对CSS初始化往往会出现浏览器之间的页面显示差异。

    • 当然,初始化样式会对SEO有一定的影响,但鱼和熊掌不可兼得,但力求影响最小的情况下初始化。

    最简单的初始化方法: * {padding: 0; margin: 0;} (强烈不建议)

    淘宝的样式初始化代码:
    body, h1, h2, h3, h4, h5, h6, hr, p, blockquote, dl, dt, dd, ul, ol, li, pre, form, fieldset, legend, button, input, textarea, th, td { margin:0; padding:0; }
    body, button, input, select, textarea { font:12px/1.5tahoma, arial, \5b8b\4f53; }
    h1, h2, h3, h4, h5, h6{ font-size:100%; }
    address, cite, dfn, em, var { font-style:normal; }
    code, kbd, pre, samp { font-family:couriernew, courier, monospace; }
    small{ font-size:12px; }
    ul, ol { list-style:none; }
    a { text-decoration:none; }
    a:hover { text-decoration:underline; }
    sup { vertical-align:text-top; }
    sub{ vertical-align:text-bottom; }
    legend { color:#000; }
    fieldset, img { border:0; }
    button, input, select, textarea { font-size:100%; }
    table { border-collapse:collapse; border-spacing:0; }

    absolute的containing block计算方式跟正常流有什么不同?

    CSS里的visibility属性有个collapse属性值是干嘛用的?在不同浏览器下以后什么区别?

    position跟display、margin collapse、overflow、float这些特性相互叠加后会怎么样?

    对BFC规范(块级格式化上下文:block formatting context)的理解?

    CSS权重优先级是如何计算的?

    请解释一下为什么会出现浮动和什么时候需要清除浮动?清除浮动的方式

    移动端的布局用过媒体查询吗?

    使用CSS预处理器吗?喜欢那个?

    CSS优化、提高性能的方法有哪些?

    浏览器是怎样解析CSS选择器的?

    在网页中的应该使用奇数还是偶数的字体?为什么呢?

    margin和padding分别适合什么场景使用?

    ◆何时应当使用margin

    需要在border外侧添加空白时。

    空白处不需要背景(色)时。

    上下相连的两个盒子之间的空白,需要相互抵消时。如15px+20px的margin,将得到20px的空白。

    ◆何时应当时用padding

    需要在border内测添加空白时。

    空白处需要背景(色)时。

    上下相连的两个盒子之间的空白,希望等于两者之和时。如15px+20px的padding,将得到35px的空白。

    元素竖向的百分比设定是相对于容器的高度吗?

    可见对于height属性取值百分比,是现对于容器高度的

    全屏滚动的原理是什么?用到了CSS的那些属性?

    什么是响应式设计?响应式设计的基本原理是什么?如何兼容低版本的IE?

    视差滚动效果,如何给每页做不同的动画?(回到顶部,向下滑动要再次出现,和只出现一次分别怎么做?)

    1. 利用background-attachment属性实现。
      background-attachment: fixed || scroll || local
      默认情况下,此属性取值scroll,页面滚动时,内容和背景一起运动,如果取值fixed,背景相对浏览器固定。
    2. 通过js控制
      在页面滚动过程中,我们获取页面的scrollTop的值,根据不同参数值去设置各自scene的top值,这样滚动页面的时候,不同的速度就出来了

    ::before和:after中双冒号和单冒号 有什么区别?解释一下这2个伪元素的作用。

    单冒号(:)用于CSS3伪类,双冒号(::)用于CSS3伪元素。
    你的直觉是:before和:after伪元素可能是 插入的内容会被注入到目标元素的前或后注入。但是,正如上面提到的,不是这样的。
    <p class="box">Other content.</p>

    p.box {
      width: 300px;
      border: solid 1px white;
      padding: 20px;
    }
     
    p.box:before {
      content: "#";
      border: solid 1px white;
      padding: 2px;
      margin: 0 10px 0 0;
    }
    
    n458945478927.jpg

    外面的盒子是这个段落。围绕有散列符号的边框表示伪元素的边界。所以,不是插入“before”到段落,而是伪元素被置于到此段落的“Other content”的前面。

    如何修改chrome记住密码后自动填充表单的黄色背景 ?

    chrome表单自动填充后,input文本框的背景会变成偏黄色的,这是由于chrome会默认给自动填充的input表单加上input:-webkit-autofill私有属性,然后对其赋予以下样式:

    input:-webkit-autofill {
    background-color: #FAFFBD;
    background-image: none;
    color: #000;
    } 
    

    但是私有属性已经无法重写

    情景一:input文本框是纯色背景的  
    input:-webkit-autofill {  
    -webkit-box-shadow: 0 0 0px 1000px white inset;  
    border: 1px solid #CCC!important;  
    }  
    思路二: 关闭浏览器自带填充表单功能  
    设置表单属性 autocomplete="off/on" 关闭自动填充表单,自己实现记住密码  
      
    <!-- 对整个表单设置 -->  
    <form autocomplete="off" method=".." action="..">  
    <!-- 或对单一元素设置 -->  
    <input type="text" name="textboxname" autocomplete="off"> 
    

    你对line-height是如何理解的?

    基线位置是由字体确定的,css的line-height指的是一行字的高度,包含了字间距,实际上就是下一行的基线到上一行的基线距离。
    单行文字的垂直居中对齐
    网上都是这么说的,把line-height值设置为height一样大小的值可以实现单行文字的垂直居中。这句话确实是正确的,但其实也是有问题的。问题在于height,看我的表述:“把line-height设置为您需要的box的大小可以实现单行文字的垂直居中”,差别在于我把height去掉了,<b>这个height是多余的</b>

      <div class="" style="line-height: 150px;border: 1px dashed #0062CC;">
        单行文字居中
      </div>
    

    多行文字居中

        <p style="line-height: 150px;border: 1px dashed #0062CC;">
          <span style="display: inline-block;font-size:12px;line-height: 1.4em;">
           这里是高度为150像素的标签内的多行文字,文字大小为12像素。
           <br>这里是第二行,用来测试多行的显示效果。
          </span>
        </p>
    

    设置元素浮动后,该元素的display值是多少?

    自动变成display:block

    怎么让Chrome支持小于12px的文字?

    chrome可以设置该私有属性,但是新版的chrome已经静止设置了
    -webkit-text-size-adjust: none;
    现在需要使用tramslate:scale(0.8);缩放的方式来缩小字体

     p span{
       font-size: 12px;
       display: block;
       transform: scale(0.8);
     }        
    

    让页面里的字体变清晰,变细用CSS怎么做?(-webkit-font-smoothing:antialiased;)

    -webkit-font-smoothing
    它有三个属性值:
    none ------ 对低像素的文本比较好
    subpixel-antialiased------默认值
    antialiased ------抗锯齿很好

    font-style属性可以让它赋值为“oblique” oblique是什么意思?

    可以理解成Italic是使用文字的斜体,Oblique是让没有斜体属性的文字倾斜!

    如果需要手动写动画,你认为最小时间间隔是多久,为什么?

    多数显示器默认频率是60Hz,即1秒刷新60次,所以理论上最小间隔为1/60*1000ms = 16.7ms

    display:inline-block什么时候会显示间隙?

    移除空格

    1. 标签衔接
      2.借助html注释符
      使用margin负值
      让闭合标签吃胶囊
      使用font-size:0

    overflow:scroll时不能平滑滚动的问题怎么处理?

    -webkit-overflow-scrolling : touch;

    有一个高度自适应的div,里面有两个div,一个高度100px,希望另一个填满剩下的高度。

    Flex方法

    .box {width:200px;height:300px;background:red;display:flex;flex-direction:column;}
    .el1 {height:100px;background:green;}
    .el2 {background:blue;flex:1}
    

    png、jpg、gif这些图片格式解释一下,分别什么时候用。有没有了解过webp?

    |格式 |压缩模式 |交错支持 |透明支持 |动画支持|
    | ------------- |:-------------:| -----:|
    |JPG |有损压缩 |支持 |不支持 |不支持|
    |PNG |无损压缩 | 支持 | 支持 | 不支持 |
    JPG的特性

    1、支持摄影图像或写实图像的高级压缩,并且可利用压缩比例控制图像文件大小。
    2、有损压缩会使图像数据质量下降,并且在编辑和重新保存JPG格式图像时,这种下降损失会累积。
    3、JPG不适用于所含颜色很少、具有大块颜色相近的区域或亮度差异十分明显的较简单的图片。
    

    PNG的特性

    1、能在保证最不失真的情况下尽可能压缩图像文件的大小。
    2、PNG用来存储灰度图像时,灰度图像的深度可多到16位,存储彩色图像时,彩色图像的深度可多到48位,并且还可存储多到16位的α通道数据。
    3、对于需要高保真的较复杂的图像,PNG虽然能无损压缩,但图片文件较大,不适合应用在Web页面上。
    

    什么是 WebP?

    WebP(发音 weppy,项目主页),
    是一种支持有损压缩和无损压缩的图片文件格式,派生自图像编码格式 VP8。根据 Google 的测试,无损压缩后的 WebP 比 PNG 文件少了
    45% 的文件大小,即使这些 PNG 文件经过其他压缩工具压缩之后,WebP 还是可以减少 28% 的文件大小。

    什么是Cookie隔离?(或者说:请求资源的时候不要让它带cookie怎么做)

    style标签写在body后与body前有什么区别?

    页面加载自上而下 当然是先加载样式
    写在head标签中利于浏览器逐步渲染(resources downloading->CSSOM+DOM->RenderTree(composite)->Layout->paint)。具体渲染过程请参考http://delai.me/code/js-and-performance/
    写在body标签后由于浏览器以逐行方式对html文档进行解析,当解析到写在尾部的样式表(外联或写在style标签)会导致浏览器停止之前的渲染,等待
    加载且解析样式表完成之后重新渲染,在windows的IE下可能会出现FOUC现象(即样式失效导致的页面闪烁问题)

    相关文章

      网友评论

        本文标题:CSS 基础知识点

        本文链接:https://www.haomeiwen.com/subject/ckcrxxtx.html