CSS面试题

CSS面试题1.有哪些方式(CSS)可以隐藏页面元素?1.opacity:0本质是将元素的透明度降为0,看起来是隐藏了,但是依然占据空间2.visibility:hidden占据空间3.display:none彻底隐藏元素,元素从文档流中消失,不占据空间4.z-index:-9999原理是将层级放到底部,看起来是隐藏了5.overflow:hidden这个只是隐藏元素溢出的部分6.transform:scale(0,0)将元素缩放为0,但是依然占据空间2.em\px\rem区别?Px:绝对

大家好,又见面了,我是你们的朋友全栈君。

 CSS选择器及其优先级

  • !important声明的样式的优先级最高
  • 内联样式:1000
  • id 选择器 100
  • 如果优先级相同,则最后出现的样式生效;
  • 继承出来的样式优先级最低;

em\px\rem\vw区别

  • px:绝对单位
  • em:相对单位,相对父节点的字体大小
  • rem:相对单位,相对于根节点html的字体大小 
  • vw:天生就是随着屏幕的宽度变化而变化

css几种定位方式?

  • static:静态定位(默认值),正常文档流定位,不脱离文档流
  • relative:相对定位,即元素相对于自身的位置进行定位,不脱离文档流
  • absolute:绝对定位,相对于 static 定位以外的第一个父元素进行定位,脱离文档流
  • fixed:固定定位,根据屏幕视口的位置来定位,脱离文档流
  • inherit:这种方式规定该元素继承父元素的position属性值。 (不常用)
  • sticky: 粘性定位,基于用户的滚动位置来定位。基本上,可以看出是position:relativeposition:fixed的结合体——当元素在屏幕内,表现为relative,当元素要滚出显示器屏幕时,表现为fixed。必须指定 top, right, bottom 或 left 四个属性中的其中一个,粘性定位才会生效。否则其行为与相对定位相同。且元素不会脱离文档流。

元素居中

 1.使用定位属性:父元素相对定位,子元素绝对定位 

CSS面试题

  2.利用css3新增属性transform: translate(-50%,-50%);

CSS面试题

  3.flex布局

CSS面试题

flex布局的属性

参考:https://www.ruanyifeng.com/blog/2015/07/flex-grammar.html
易考点:
flex-flow:是flex-direction和flex-wrap的简写形式
justify-content:定义项目在主轴方向上的排列方式

     假设主轴是水平方向:

  •      flex-start:左对齐
  •      flex-end:右对齐
  •      center:居中
  •      space-between:两端对齐,项目之间的间距相等
  • CSS面试题
  •      space-around:每个项目两侧间隔相等,所以项目之间的间隔比项目与边缘间隔大一倍
  • CSS面试题

flex
    flex-grow、 flex-shrink 、flex-basic的简写 默认是0 1 auto,后面两个值可选

该属性有两个快捷值auto(1 1 auto)和none(0 0 auto)
 

标准盒子模型和IE盒子模型

盒模型分为两种:标准和怪异
盒模型的属性包含margin padding border content
标准盒模型的width = content
怪异盒模型的width = border + padding + content
box-sizing:border-box将采用怪异盒模型
Box-sizing:content-box将采用标准盒模型

 display的属性值及其作用

属性值 作用
none 元素不显示,并且会从文档流中移除。既在网页中不占任何的位置。
block 块类型。默认宽度为父元素宽度,可设置宽高,换行显示。
inline 行内元素类型。默认宽度为内容宽度,不可设置宽高,同行显示。
inline-block 默认宽度为内容宽度,可以设置宽高,同行显示。
list-item 像块类型元素一样显示,并添加样式列表标记。
table 此元素会作为块级表格来显示。
inherit 规定应该从父元素继承display属性的值。

display的block、inline和inline-block的区别

(1)行内元素

  • 设置宽高无效;
  • 不支持上下margin设置,支持左右margin的设置;支持padding设置。
  • 不会自动换行;

(2)块级元素

  • 可以设置宽高;
  • 设置margin和padding都有效;
  • 可以自动换行;
  • 多个块状,默认排列从上到下。

重绘回流

1. 浏览器渲染机制
浏览器采用流式布局模型(Flow Based Layout)
浏览器会把HTML解析成DOM,把CSS解析成CSSOM,DOM和CSSOM合并就产生了渲染树(Render Tree)。
然后计算他们在页面上的大小和位置,最后把节点绘制到页面上。
2.重绘
由于节点的属性发生改变或者由于样式发生改变而不会影响布局的,称为重绘,例如outline, visibility, color、background-color等,重绘的代价是高昂的,因为浏览器必须验证DOM树上其他节点元素的可见性。
3.回流
回流是布局需要改变就称为回流。回流是影响浏览器性能的关键因素,因为其变化涉及到部分页面(或是整个页面)的布局更新。一个元素的回流可能会导致了其所有子元素以及DOM中紧随其后的节点、祖先节点元素的随后的回流。
回流必定会发生重绘,重绘不一定会引发回流
4.减少重绘与回流
1、使用 visibility(重绘) 替换 display: none (回流)
2、避免使用table布局,可能很小的一个小改动会造成整个 table 的重新布局。
3、尽可能在DOM树的最末端改变class,
4、合并多次对DOM和样式的修改,然后一次处理掉

chrome的最小字体12px限制最终解决办法

利用css3的transform属性
-webkit-transform: scale(0.90);

BFC

什么是BFC?看这一篇就够了_Leon的博客-CSDN博客_bfc

简单来说就是,BFC是一个完全独立的渲染区域,让空间里的子元素不会影响到外面的布局。

怎样触发BFC

这里简单列举几个触发BFC使用的CSS属性

  • overflow: hidden
  • display: inline-block
  • position: absolute
  • position: fixed
  • display: table-cell
  • display: flex
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/138256.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 智能优化算法改进算法 -附代码[通俗易懂]

    智能优化算法改进算法 -附代码[通俗易懂]智能优化算法改进算法摘要:为了方便大家对智能优化算法进行改进,复现多种智能优化改进算法供大家参考。所有代码均根据已经发表的文章,来复现方便大家参考别人的原理,代码会不定时更新。1.文献复现:基于变因子加权学习与邻代维度交叉策略的改进乌鸦算法Matlab代码[1]赵世杰,高雷阜,于冬梅,徒君.基于变因子加权学习与邻代维度交叉策略的改进CSA算法[J].电子学报,2019,47(01):40-48.2.文献复现:自适应t分布变异的缎蓝园丁鸟优化算法Matlab代码[1]韩斐斐,刘升.基于自适

    2022年5月23日
    41
  • vuex使用教程(最好最详细的乒乓教程)

    最详细的Vuex教程什么是Vuex?vuex是一个专门为vue.js设计的集中式状态管理架构。状态?我把它理解为在data中的属性需要共享给其他vue组件使用的部分,就叫做状态。简单的说就是data中需要共用的属性。引入Vuex(前提是已经用Vue脚手架工具构建好项目)1、利用npm包管理工具,进行安装vuex。在控制命令行中输入下边的命令就可以了。npminstallvuex

    2022年4月14日
    112
  • 流程引擎标准定义_开源流程引擎

    流程引擎标准定义_开源流程引擎1.1流程定义引擎功能说明管理员无需编程基础便能快捷地定义出符合本单位需求的各项工作流程,协同办公平台流程定义项目丰富,能够规范企业业务流程,发挥企业各种资源及系统的最大效能。流程定义主要包括流程的基本属性、节点定义、相关表单、审核常用语、流程归档。可自定义流程的使用范围,序号一级功能二级功能功能详细需求说明1. 

    2022年10月20日
    0
  • 快速批量去除图片水印方法大全~~

    原文地址:http://blog.163.com/simonyao_cool/blog/static/16512555720107311858809/

    2022年4月7日
    709
  • python模块有哪些_python typeerror

    python模块有哪些_python typeerrorpython将自己写的模块上传到PyPI服务器,报错error:<urlopenerror[SSL:CERTIFICATE_VERIFY_FAILED]certificatever

    2022年7月31日
    2
  • getcomponent_getsocketopt

    getcomponent_getsocketoptGetMessage函数功能GetMessage是计算机编程中的一个函数,从调用线程的消息队列里取得一个消息并把其放于指定的结构。GetMessage函数可取得与指定窗口联系的消息和由PostThreadMesssge寄送的线程消息,接收一定范围的消息值,不接收属于其他线程或应用程序的消息。GetMessage获取消息成功后,线程把从消息队列中删除该消息,函数会一直等待直到有消息到来才有返回值。函数声明WINUSERAPIBOOLWINAPIGetMessage(_Out_LPMS

    2022年9月13日
    0

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号