看看这些前端面试题,带你搞定高频知识点(五)

看看这些前端面试题,带你搞定高频知识点(五)

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

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

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

flex布局

  *{margin: 0;padding: 0;}  .container{    display: flex;   }  .left{    width: 300px;    height: 100vh;    background-color: #f00;  }  .main{    flex: 1;    background-color: #ae5aca;   }  

登录后复制

浮动+BFC

  *{margin: 0;padding: 0;}  .container {    height: 100vh;  }  .left {    float: left;    width: 300px;    height: 100%;    background-color: #f00;  }  .main {    height: 100%;    background-color: #ae5aca;    overflow: hidden;  }  

登录后复制

看看这些前端面试题,带你搞定高频知识点(五)

立即学习“前端免费学习笔记(深入)”;

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

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

align-content:作用于纵轴多行元素,一行元素不起作用。【相关推荐:web前端开发】

  .container {    background-color: #efefef;    border: 1px solid #888;    margin-top: 3rem;    height: 300px;    display: flex;    flex-wrap: wrap;    /* 纵轴多元素一起居中 */    align-content: center;  }  .item {    width: 200px;    height: 100px;    background-color: #ccc;    border: 1px solid #aaa;  }  
1
2
3
4
5
6
7

登录后复制

看看这些前端面试题,带你搞定高频知识点(五)

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

  .container {    background-color: #efefef;    border: 1px solid #888;    margin-top: 3rem;    height: 300px;    display: flex;    flex-wrap: wrap;    /* 纵轴单元素居中 */    align-items: center;  }  .item {    width: 200px;    height: 100px;    background-color: #ccc;    border: 1px solid #aaa;  }  
1
2
3
4
5
6
7

登录后复制

看看这些前端面试题,带你搞定高频知识点(五)

面试官: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 元素基于其元素属性按照优先级顺序占据这个空间。优先级如下:

看看这些前端面试题,带你搞定高频知识点(五)

 想了解更深层叠上下文:推荐文章:web前端开发 。

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

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

层叠黄金准则:

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

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

整出代码如下:

  .first {    background-color: red;    height: 3rem;    z-index: 2;    opacity: 0.99;  }  .item1 {    z-index: 0;    height: 100%;    width: 3rem;    background-color: orange;  }  .second {    background-color: blue;    height: 3rem;    margin-top: -1.5rem;    z-index: 3;    position: relative;  }    .item2 {    z-index: 999;    height: 100%;    width: 3rem;    background-color: green;  }  

登录后复制

看看这些前端面试题,带你搞定高频知识点(五)

面试官:什么是 Data URL?

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

使用看看这些前端面试题,带你搞定高频知识点(五)这种方式引用图片,不需要再发请求获取图片。

使用 Data URL 也有一些缺点:

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

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

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

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

看看这些前端面试题,带你搞定高频知识点(五)

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

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

浮动

                                * {                margin: 0;                padding: 0;            }            .container {                border: 1px solid black;                overflow: hidden;                padding: 0px 100px;                min-width: 100px;            }            .left {                background-color: greenyellow;                float: left;                width: 100px;                margin-left: -100%;                position: relative;                left: -100px;            }            .center {                background-color: darkorange;                float: left;                width: 100%;            }            .right {                background-color: darkgreen;                float: left;                width: 100px;                margin-left: -100px;                position: relative;                left: 100px;            }                    









登录后复制

看看这些前端面试题,带你搞定高频知识点(五)

(学习视频分享:web前端开发、web前端开发)

以上就是看看这些前端面试题,带你搞定高频知识点(五)的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2864845.html

(0)
上一篇 2025年3月10日 17:33:13
下一篇 2025年2月23日 16:09:10

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • css实现登录按钮炫酷效果(附代码实例)

    今天在网上看到一个炫酷的登录按钮效果;初看时感觉好牛掰;但是一点一点的抛开以后发现,并没有那么难;我会将全部代码贴出来;如果有不对的地方,大家指点一哈。 分析 我们抛开before不谈的话;其实原理和就是通过背景大小以及配合位置达到颜色渐变…

    2025年3月10日
    200
  • 全面梳理下CSS盒模型的相关知识点

    css 盒模型是 css 基础的重点难点,因此常被面试官们拿来考察候选人对前端基础的掌握程度,这篇文章将对 css 盒模型知识点进行全面的梳理。 我们先看个例子:下面的 div 元素的总宽度是多少呢? nbsp;html>     C…

    2025年3月10日 编程技术
    200
  • css超出显示…

    css超出显示省略号的步骤:1、将文本内容超出容器的部分进行隐藏;2、确保文本能够正确地换行,以适应容器的宽度或高度;3、当文本内容超出容器的宽度或高度时,将会隐藏超出部分的内容,可以在隐藏部分的末尾添加省略;4、使用CSS的width和h…

    2025年3月10日
    200
  • 如何使用CSS使div标签的高度与浏览器窗口的高度相等?

    When working on web development projects, there are often scenarios where you need to give a div tag the full height of …

    2025年3月10日
    200
  • css如何实现三角形

    css实现三角形的方法:1、使用边框实现三角形,利用透明边框和实色边框的组合,可以创建不同方向和大小的三角形;2、使用伪元素实现三角形,通过使用伪元素来创建一个占据父元素一半大小的实心三角形;3、使用transform属性实现三角形,通过调…

    2025年3月10日
    200
  • 怎么实现css禁止点击事件

    实现css禁止点击事件的方法有使用CSS的pointer-events属性和使用JavaScript禁用点击事件。详细介绍:1、CSS的pointer-events属性可以控制元素是否可以触发鼠标事件。默认情况下,pointer-event…

    2025年3月10日
    200
  • 如何使用CSS创建渐变阴影?

    随着网络的不断发展,制作漂亮的 UI 是提高客户在网站上的参与度的最重要的工作之一。改善前端外观的方法之一是在 CSS 中应用渐变阴影。应用渐变阴影的两种最重要的方法是线性渐变和径向渐变。 渐变阴影可用于吸引用户对特定信息的注意力,应用悬停…

    2025年3月10日
    200
  • 在CSS中创建水平可滚动的部分

    水平可滚动的部分是一种常见的网页设计模式,用于展示超出视口宽度的内容。这种设计模式允许用户水平滚动,提供了一种独特而吸引人的方式来展示大型图像、画廊、时间轴、地图和其他内容。这是通过使用CSS属性,如overflow−x: auto或ove…

    2025年3月10日
    200
  • css里iframe是什么

    css里iframe是一种用于在网页中嵌入其他网页或文档的标签,可以控制网页的布局、字体、颜色、背景等方面的样式。用于在一个网页中嵌入另一个网页或文档,可以创建一个独立的窗口,显示其他网页的内容,而不影响主页面的布局和样式。通过在ifram…

    2025年3月10日
    200
  • CSS3的新特性一览:如何使用CSS3实现媒体查询

    CSS3的新特性一览:如何使用CSS3实现媒体查询 随着移动设备的普及,网页的响应式设计变得越来越重要。CSS3为前端开发人员提供了一系列强大的特性,其中最重要的特性之一就是媒体查询(Media Queries)。通过使用媒体查询,我们可以…

    2025年3月10日
    200

发表回复

登录后才能评论