• 首页 首页 icon
  • 工具库 工具库 icon
    • IP查询 IP查询 icon
  • 内容库 内容库 icon
    • 快讯库 快讯库 icon
    • 精品库 精品库 icon
    • 问答库 问答库 icon
  • 更多 更多 icon
    • 服务条款 服务条款 icon

手撕面试题HTML+CSS高频知识点五

武飞扬头像
亦世凡华、
帮助8

目录

面试官:css 如何实现左侧固定 300px,右侧自适应的布局?

面试官:flex 布局中 align-content 与 align-items 有何区别?

面试官:Grid 布局的优势在哪里?

面试官:Flex 布局中的 flex-basis 与 width 有何区别?

面试官:css 加载会阻塞 DOM 树的解析和渲染吗?

面试官:什么是层叠上下文 (stacking contect),谈谈对它的理解

面试官:z-index: 999 元素一定会置于 z-index: 0 元素之上吗?

面试官:什么是 Data URL?

面试官:网站设置字体时,如何设置优先使用系统默认字体?

面试官:CSS如何实现圣杯布局?


        每天10道题,100天后,搞定所有前端面试的高频知识点,加油!!!,在看文章的同时,希望不要直接看答案,先思考一下自己会不会,如果会,自己的答案是什么?想过之后再与答案比对,是不是会更好一点,当然如果你有比我更好的答案,欢迎评论区留言,一起探讨技术之美。

面试官:css 如何实现左侧固定 300px,右侧自适应的布局?

我:呃~,好的,可以采用flex布局,或者浮动 BFC,整出代码如下:

flex布局

  1.  
    <style>
  2.  
    *{margin: 0;padding: 0;}
  3.  
    .container{
  4.  
    display: flex;
  5.  
    }
  6.  
    .left{
  7.  
    width: 300px;
  8.  
    height: 100vh;
  9.  
    background-color: #f00;
  10.  
    }
  11.  
    .main{
  12.  
    flex: 1;
  13.  
    background-color: #ae5aca;
  14.  
    }
  15.  
    </style>
  16.  
    <body>
  17.  
    <div class="container">
  18.  
    <div class="left"></div>
  19.  
    <div class="main"></div>
  20.  
    </div>
  21.  
    </body>
学新通

浮动 BFC

  1.  
    <style>
  2.  
    *{margin: 0;padding: 0;}
  3.  
    .container {
  4.  
    height: 100vh;
  5.  
    }
  6.  
    .left {
  7.  
    float: left;
  8.  
    width: 300px;
  9.  
    height: 100%;
  10.  
    background-color: #f00;
  11.  
    }
  12.  
    .main {
  13.  
    height: 100%;
  14.  
    background-color: #ae5aca;
  15.  
    overflow: hidden;
  16.  
    }
  17.  
    </style>
  18.  
    <body>
  19.  
    <div class="container">
  20.  
    <div class="left"></div>
  21.  
    <div class="main"></div>
  22.  
    </div>
  23.  
    </body>
学新通

学新通

面试官:flex 布局中 align-content 与 align-items 有何区别?

我:呃~,它们都是作用于纵轴的元素,具体区别如下:

align-content:作用于纵轴多行元素,一行元素不起作用。

  1.  
    <style>
  2.  
    .container {
  3.  
    background-color: #efefef;
  4.  
    border: 1px solid #888;
  5.  
    margin-top: 3rem;
  6.  
    height: 300px;
  7.  
    display: flex;
  8.  
    flex-wrap: wrap;
  9.  
    /* 纵轴多元素一起居中 */
  10.  
    align-content: center;
  11.  
    }
  12.  
    .item {
  13.  
    width: 200px;
  14.  
    height: 100px;
  15.  
    background-color: #ccc;
  16.  
    border: 1px solid #aaa;
  17.  
    }
  18.  
    </style>
  19.  
    <body>
  20.  
    <div class="container">
  21.  
    <div class="item">1</div>
  22.  
    <div class="item">2</div>
  23.  
    <div class="item">3</div>
  24.  
    <div class="item">4</div>
  25.  
    <div class="item">5</div>
  26.  
    <div class="item">6</div>
  27.  
    <div class="item">7</div>
  28.  
    <div class="item"></div>
  29.  
    <div class="item"></div>
  30.  
    <div class="item"></div>
  31.  
    </div>
  32.  
    </body>
学新通

学新通

align-items:作用于纵轴单行元素

  1.  
    <style>
  2.  
    .container {
  3.  
    background-color: #efefef;
  4.  
    border: 1px solid #888;
  5.  
    margin-top: 3rem;
  6.  
    height: 300px;
  7.  
    display: flex;
  8.  
    flex-wrap: wrap;
  9.  
    /* 纵轴单元素居中 */
  10.  
    align-items: center;
  11.  
    }
  12.  
    .item {
  13.  
    width: 200px;
  14.  
    height: 100px;
  15.  
    background-color: #ccc;
  16.  
    border: 1px solid #aaa;
  17.  
    }
  18.  
    </style>
  19.  
    <body>
  20.  
    <div class="container">
  21.  
    <div class="item">1</div>
  22.  
    <div class="item">2</div>
  23.  
    <div class="item">3</div>
  24.  
    <div class="item">4</div>
  25.  
    <div class="item">5</div>
  26.  
    <div class="item">6</div>
  27.  
    <div class="item">7</div>
  28.  
    <div class="item"></div>
  29.  
    <div class="item"></div>
  30.  
    <div class="item"></div>
  31.  
    </div>
  32.  
    </body>
学新通

学新通

面试官:Grid 布局的优势在哪里?

我:呃~,Flex 布局是轴线布局,只能指定"项目"针对轴线的位置,可以看作是一维布局。 Grid 布局则是将容器划分成"行"和"列",产生单元格,然后指定"项目所在"的单元格,可以看作是二维布局。 Grid 布局远比 Flex 布局强大。

面试官:Flex 布局中的 flex-basis 与 width 有何区别?

我:呃~,flex-basis 的值为理想情况,而在实际情况中可能被压缩,当 flex-direction 为 column 时,主轴为纵轴,此时 flex-basis 与 height 对应

面试官:css 加载会阻塞 DOM 树的解析和渲染吗?

我:呃~,css 加载会直接影响网页的渲染,因为只有 css 加载完毕,构建完 CSSOM 后,渲染树(Render Tree)才会构建,然后渲染成位图,如果 html 中有加载 script 的话,还会间接影响 DOM 树的解析,因为 javascript 的下载、解析和执行和阻塞 DOM 树的解析,而 javascript 中有可能访问 CSSOM,比如 Element.getBoundingClientRect,因此 CSSOM 构建完毕以后才会开始 javascript 的执行,间接阻塞 dom 树的解析。

面试官:什么是层叠上下文 (stacking contect),谈谈对它的理解

我:呃~,好的,层叠上下文就是对这些 HTML 元素的一个三维构想。众 HTML 元素基于其元素属性按照优先级顺序占据这个空间。优先级如下:

学新通

 想了解更深层叠上下文:推荐文章:深入理解CSS中的层叠上下文和层叠顺序

面试官:z-index: 999 元素一定会置于 z-index: 0 元素之上吗?

我:呃~,不会,我们在进行层叠上下文时,会优先比较父级,如果父级是层叠上下文,子级即使有z-index也不再起作用了,如果父级层叠上下文层叠顺序相等,那么采取后来居上原则,前者覆盖后者。如果父级是普通元素,子级层叠比较就不受父级的影响,谁的层叠顺序高谁就先展示。

层叠黄金准则:

谁大谁上:当具有明显的层叠水平标示的时候,如识别的z-indx值,在同一个层叠上下文领域,层叠水平值大的那一个覆盖小的那一个。通俗讲就是官大的压死官小的。

后来居上:当元素的层叠水平一致、层叠顺序相同的时候,在DOM流中处于后面的元素会覆盖前面的元素。

整出代码如下:

  1.  
    <style>
  2.  
    .first {
  3.  
    background-color: red;
  4.  
    height: 3rem;
  5.  
    z-index: 2;
  6.  
    opacity: 0.99;
  7.  
    }
  8.  
    .item1 {
  9.  
    z-index: 0;
  10.  
    height: 100%;
  11.  
    width: 3rem;
  12.  
    background-color: orange;
  13.  
    }
  14.  
     
  15.  
    .second {
  16.  
    background-color: blue;
  17.  
    height: 3rem;
  18.  
    margin-top: -1.5rem;
  19.  
    z-index: 3;
  20.  
    position: relative;
  21.  
    }
  22.  
    .item2 {
  23.  
    z-index: 999;
  24.  
    height: 100%;
  25.  
    width: 3rem;
  26.  
    background-color: green;
  27.  
    }
  28.  
    </style>
  29.  
    <body>
  30.  
    <div class="first">
  31.  
    <div class="item1"></div>
  32.  
    </div>
  33.  
    <div class="second">
  34.  
    <div class="item2"></div>
  35.  
    </div>
  36.  
    </body>
学新通

学新通

面试官:什么是 Data URL?

我:呃~,Data URL 是将图片转换为 base64 直接嵌入到了网页中。

使用<img src="data:[MIME type];base64"/>这种方式引用图片,不需要再发请求获取图片。

使用 Data URL 也有一些缺点:

base64 编码后的图片会比原来的体积大三分之一左右。

Data URL 形式的图片不会缓存下来,每次访问页面都要被下载一次。可以将 Data URL 写入到 CSS 文件中随着 CSS 被缓存下来。

面试官:网站设置字体时,如何设置优先使用系统默认字体?

我:呃~,system-ui 将会自动选取系统默认字体作为字体。

学新通

面试官:CSS如何实现圣杯布局?

我:呃~,圣杯布局是指两端宽度固定,中间自适应。在日常开发中,圣杯布局的使用频率是比较高的。举一个简单的浮动例子,当然也可以使用定位或flex布局,整出代码如下:

浮动

  1.  
    <!DOCTYPE html>
  2.  
    <html>
  3.  
    <head>
  4.  
    <meta charset=utf-8>
  5.  
    <style type="text/css">
  6.  
    * {
  7.  
    margin: 0;
  8.  
    padding: 0;
  9.  
    }
  10.  
    .container {
  11.  
    border: 1px solid black;
  12.  
    overflow: hidden;
  13.  
    padding: 0px 100px;
  14.  
    min-width: 100px;
  15.  
    }
  16.  
    .left {
  17.  
    background-color: greenyellow;
  18.  
    float: left;
  19.  
    width: 100px;
  20.  
    margin-left: -100%;
  21.  
    position: relative;
  22.  
    left: -100px;
  23.  
    }
  24.  
    .center {
  25.  
    background-color: darkorange;
  26.  
    float: left;
  27.  
    width: 100%;
  28.  
    }
  29.  
    .right {
  30.  
    background-color: darkgreen;
  31.  
    float: left;
  32.  
    width: 100px;
  33.  
    margin-left: -100px;
  34.  
    position: relative;
  35.  
    left: 100px;
  36.  
    }
  37.  
    </style>
  38.  
    </head>
  39.  
    <body>
  40.  
    <section class="container">
  41.  
    <article class="center"><br /><br /><br /></article>
  42.  
    <article class="left"><br /><br /><br /></article>
  43.  
    <article class="right"><br /><br /><br /></article>
  44.  
    </section>
  45.  
    </body>
  46.  
    </html>
学新通

学新通

这篇好文章是转载于:学新通技术网

  • 版权申明: 本站部分内容来自互联网,仅供学习及演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,请提供相关证据及您的身份证明,我们将在收到邮件后48小时内删除。
  • 本站站名: 学新通技术网
  • 本文地址: /boutique/detail/tanhffjgbh
系列文章
更多 icon
同类精品
更多 icon
继续加载