CSS面试题

CSS面试题

如何理解HTML语义化

HTML语义化就是在书写HTML结构时,使用HTML中具有明显语义化的标签,例如p标签、ul标签、header标签等。增加代码的可读性,让程序员与搜索引擎(SEO)更容易读懂。

块级元素和内联元素

块级元素:display: block/table,p、ul、div、h1等

内联元素:display: inline/inline-block,img、span、input、button

盒模型计算

offsetWidth =(内容宽度+内边距+边框),无外边距

margin纵向重叠

相邻元素的margin-top和margin-bottom会发生重叠,空白内容的p标签也会重叠

margin负值

margin-left和margin-top为负值,自身向左和向上移动;

margin-right和margin-bottom为负值,自身不动,右边和下面的元素向左和向上移动

BFC

position为absolute、fixed

float不为none

overflow不为visible

display为flex、inline-block

圣杯布局

双飞翼布局

flex布局画骰子

javascript 复制代码
<div class="container">
    <div class="item"></div>
    <div class="item"></div>
    <div class="item"></div>
</div>

.container{
        width: 200px;
        height: 200px;
        border: 1px solid black;
        padding: 10px;

        display: flex;
        justify-content: space-between;
 }
 .item{
        width: 40px;
        height: 40px;
        background-color: #888;
        border-radius: 50%;
 }
 .item:nth-child(2){
        align-self: center;
 }
.item:nth-child(3){
        align-self: flex-end;
}

line-height继承

javascript 复制代码
<body>
	<p>文字</p>
</body>
body{
	font-size: 20px;
	line-height: 20px; //此时p标签的line-height为20px
	line-height: 1.5; //此时p标签的line-height为16*1.5=24px
	line-height: 200%; //此时p标签的line-height为20*200%=40px
}
p{
	background-color: #ccc;
	font-size: 16px;
}

rem

javascript 复制代码
//依据根元素font-size决定
html{
	font-size: 100px;
}
div{
	width: 2rem; //宽度为200px
}
<div>111</div>

vw/vh

javascript 复制代码
window.screen.height //屏幕高度
window.innerHeight //视口高度,减去浏览器上方、下方,真正元素放置的地方
document.body.clientHeight //元素撑起的高度

1vw //网页视口宽度的1/100
1vh //网页视口高度的1/100
相关推荐
lichenyang4531 分钟前
鸿蒙 Web 容器(二):H5 和 ArkTS 说话前,先定一份「协议」
前端
JYeontu4 分钟前
开箱流水加载动画
前端·javascript·css
RANxy5 分钟前
AntV 入门系列:G6 图可视化实战
前端
尽欢i7 分钟前
Vue3 customRef 封神教程:防抖、本地存储、自动埋点一套搞定,模板干干净净
前端·javascript·vue.js
VOLUN10 分钟前
TypeScript封装通用RESTful BaseAPI,后台接口代码精简80%
前端·javascript
胡永双10 分钟前
Hexo + GitHub Pages搭建个人Blog教程(三)
前端
hunterandroid13 分钟前
[Android 从零到一] 权限管理:运行时权限与最佳实践
前端
kyrie2815 分钟前
Redux 完整基础操作(原生 Redux,不结合 React-Redux)
前端
因_崔斯汀16 分钟前
Vue 模板编译:HTML 是怎么变成 JS 的?
前端·vue.js