Css3 常见技术面试题(二)

本文详细探讨了CSS3中的Canvas与SVG的区别,包括它们的特性和应用场景。接着讨论了多种CSS实现水平居中的方法,以及清除浮动的策略。此外,还详细阐述了img标签的alt和title属性的功能差异,绝对定位与相对定位的异同,并介绍了三栏布局的多种实现方式。最后,文章深入讲解了CSS3动效的原理、作用和实现方法,以及伪类的使用技巧。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1 Canvas和SVG图形的区别是什么

1.1 Canvas

通过js绘制2D图形
逐像素进行渲染
位置发生改变会重新进行绘制

1.2 SVG

一种使用XML描述的2D图形的语言
SVG继续XML意味着SVG DOM中的每个元素都是可用的,可以为某个元素附加js事件处理器
在 SVG 中,每个被绘制的图形均被视为对象。如果 SVG 对象的属性发生变化,那么浏览器能够自动重现图形。

1.3 区别

Canvas依赖分辨率,SVG不依赖
Canvas不支持事件处理器,SVG支持
Canvas弱的文本渲染能力,SVG适合带有大型渲染区域的应用程序(比如谷歌地图)
Canvas最适合图像密集型的游戏,其中的许多对象会被频繁重绘 SVG不适合游戏应用
Canvas能够以 .png 或 .jpg 格式保存结果图像
SVG复杂度高会减慢渲染速度(任何过度使用 DOM 的应用都不快)

2 Css如何实现水平居中

1、行内元素水平居中:text-align: center;
2、固定宽块状元素水平居中:margin:0 auto;
3、不固定宽块状元素水平居中:
(1)设置display:inline 然后给父元素设置text-align:center
(2)绝对定位让元素向右偏移50%,然后向左偏移自身的50%
在这里插入图片描述
(3)弹性布局1
在这里插入图片描述
(4)弹性布局2
CSS3的fit-content配合左右margin为auto实现水平居中方法
在这里插入图片描述

3 清除浮动的几种方法

1、在浮动元素下方加空div,设置clear:both

2、给浮动元素的父元素设置高度

3、以浮制浮(父元素同时浮动) 缺点:浮动多了容易出问题

4、结尾处加br 设置clear:both

5、给父级添加overflow:hidden

6、给父元素加overflow:auto

7、给父元素定义display:table

8、父级div定义伪类 :after和zoom
使用 zoom:1触发 hasLayout
在这里插入图片描述

### 关于 Vue 和 CSS常见面试题整理 以下是关于 Vue 和 CSS 的一些常见面试题目及其解答: #### Vue 部分 1. **什么是 Vue.js 中的响应式数据绑定?它是如何工作的?** - 响应式数据绑定是通过观察者模式实现的数据与视图之间的双向绑定。当数据发生变化时,视图会自动更新;反之亦然[^1]。 2. **Vue.js 中 `v-model` 双向绑定的工作原理是什么?** - `v-model` 实现的核心在于监听输入框的变化事件并同步到模型中,同时将模型中的值应用到 DOM 上。具体来说,它利用了 JavaScript 的 getter 和 setter 方法以及依赖追踪机制来完成这一过程[^1]。 3. **解释一下 Vue.js 生命周期钩子函数的作用和顺序。** - Vue 组件生命周期包括多个阶段:创建 (`beforeCreate`, `created`)、挂载 (`beforeMount`, `mounted`)、更新 (`beforeUpdate`, `updated`) 和销毁 (`beforeDestroy`, `destroyed`)。这些钩子允许开发者在特定时刻执行自定义逻辑[^2]。 4. **组件化的意义是什么?Vue 如何支持组件化开发?** - 组件化是一种软件设计方法论,旨在提高代码复用性和可维护性。Vue 提供了一套完整的 API 来构建独立的功能模块——即组件,并且可以通过单文件组件 (.vue 文件) 将模板、脚本和样式封装在一起[^1]。 --- #### CSS 部分 1. **CSS Flexbox 是什么?它的主要用途有哪些?** - Flexbox(弹性盒子布局)是一个一维布局方案,用于解决复杂页面布局问题。它可以轻松处理水平居中、垂直排列等问题,非常适合动态调整大小的内容区域[^3]。 2. **BEM 命名法的意义是什么?为什么推荐使用 BEM?** - BEM 表示 Block Element Modifier,这是一种基于模块化原则的命名约定方式。采用这种风格可以帮助团队成员更清晰地理解 HTML/CSS 结构关系,减少冲突风险的同时提升协作效率[^4]。 3. **伪类选择器和伪元素有什么区别?举例说明它们的应用场景。** - 伪类用来匹配某些状态下的元素(如`:hover`, `:active`),而伪元素则表示实际存在于文档流之外的部分(比如首字母或行内生成内容)。两者虽然都以冒号开头但功能完全不同[^5]。 4. **媒体查询 Media Query 在响应式网页设计中有何作用?** - 使用 @media 规则可以根据不同的设备特性设置相应的样式规则,从而让同一个网站适应多种屏幕尺寸需求。这是现代前端开发不可或缺的技术之一[^6]。 --- ### 示例代码片段 以下是一些简单的 Vue 和 CSS 示例代码展示其基本概念: ```html <!-- Vue 单文件组件 --> <template> <div class="container"> <input type="text" v-model="message" /> <p>{{ message }}</p> </div> </template> <script> export default { data() { return { message: &#39;Hello Vue!&#39; }; } }; </script> <style scoped> .container { display: flex; justify-content: center; } </style> ``` ```css /* 简单的 Flexbox 应用 */ .parent { display: flex; align-items: center; /* 垂直居中 */ } .child { margin-right: 10px; } ``` ---
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值