Web前端CSS面试题(含答案)

CSS选择器的优先级是怎样的?

CSS选择器的优先级是:内联 > ID选择器 > 类选择器 > 标签选择器
到具体的计算层面,优先级是由A,B,C,D的值来决定的,其中它们的值计算规则如下:

  • A的值等于1的前提是存在内联样式,否则A=0;
  • B的值等于 ID选择器 出现的次数;
  • C的值等于 类选择器属性选择器伪类 出现的总次数;
  • D的值等于 标签选择器伪元素 出现的总次数;

就比如下面的选择器,它不存在内联样式,所有A=0,不存在id选择器B=0,存在一个类选择器C=1,存在三个标签选择器D=3,那么最终计算结果为:{0,0,1,3}

ul ol li .red {
   
	...
}

按照这个计算方式,下面的计算结果为:{0,1,0,0}

#red{
   
 ...
}

我们的比较优先级的方式是从A到D去比较值的大小,A,B,C,D权重从左到右,依次减小。判断优先级时,从左到右,一一比较,直到比较出最大值,即可停止。

比如第二个例子的B与第一个例子的B相比,1>0,接下来就不需要比较了,第二个选择器的优先级更高。

link和@import的区别?

  • link属于XHTML标签,而@import是CSS提供的。
  • 页面加载时,link会同时被加载,而@import引用的CSS会等到页面被加载完再加载。
  • import只在IE 5 以上才能识别,而link是XHTML标签,无兼容问题。
  • link方式的样式权重高于@import的权重。
  • 使用dom控制样式时的差别。当使用javascript控制dom去改变样式的时候,只能使用link标签,因为@import不时dom可以控制的。

有哪些方式(CSS)可以隐藏页面元素?

  • opacity:0 : 本质上是将元素的透明度将为0,就看起来隐藏了,但是依然占据空间且可以交互。
  • visibility:hidden:与上一个方法类似的效果,占据空间,但是不可以交互了。
  • overflow:hidden:这个只隐藏元素溢出的部分,但是占据空间且不可交互。
  • display:none:这个是彻底隐藏了元素,元素从文档流中小时,即不占据空间也不交互,也不影响布局。
  • z-index:
以下是一些拼多多面试中可能会涉及到的前端面试题和答案: 1. 说一下 CSS 盒模型? 答:CSS 盒模型是指在网页布局时,每个元素所占据的空间可以看做是一个矩形的盒子。盒模型包括内容区域(content)、内边距区域(padding)、边框区域(border)和外边距区域(margin)。 2. 什么是闭包? 答:闭包是指在函数内部定义的函数,它可以访问到它外部函数的变量和参数,即使外部函数已经执行完毕,闭包仍然可以访问到这些变量和参数。闭包在 JavaScript 中非常常见,比如在事件处理器、定时器、Ajax 请求等场景中都会用到。 3. 什么是跨域?如何解决跨域问题? 答:跨域是指在浏览器中,如果一个网页的脚本试图访问不同源(协议、域名、端口)的服务器资源,就会引发跨域问题。为了保证浏览器的安全性,浏览器会限制脚本访问不同源的资源。 解决跨域问题的方法有很多种,常用的方法包括: - JSONP:利用 <script> 标签可以跨域访问资源的特性,通过动态创建 <script> 标签,将需要获取的数据以参数的形式传递给服务器,服务器在返回时将数据包裹在一个函数调用中,从而实现跨域获取数据。 - CORS:CORS(Cross-Origin Resource Sharing)是一种基于 HTTP 头部的跨域解决方案,它允许服务器在响应头中设置 Access-Control-Allow-Origin 头部,表明哪些源可以访问该资源。 - 代理:通过在同源服务器上设置代理,在代理服务器上转发请求,从而实现跨域访问资源。 4. 如何实现一个简单的 Promise? 答: ```javascript function MyPromise(fn) { var self = this; self.value = null; self.error = null; self.onFulfilled = null; self.onRejected = null; function resolve(value) { setTimeout(function() { self.value = value; self.onFulfilled(self.value); }, 0); } function reject(error) { setTimeout(function() { self.error = error; self.onRejected(self.error); }, 0); } fn(resolve, reject); } MyPromise.prototype.then = function(onFulfilled, onRejected) { var self = this; self.onFulfilled = onFulfilled; self.onRejected = onRejected; }; ``` 5. 什么是事件冒泡和捕获?如何阻止事件冒泡? 答:事件冒泡和捕获是指在页面中,当一个元素触发了某个事件时,该事件会先从最外层的元素开始依次向下传递,直到触发该事件的元素为止,这个过程称为事件冒泡;相反,事件捕获是从最外层元素开始,依次向下寻找触发该事件的元素,这个过程称为事件捕获。 阻止事件冒泡的方法包括: - 使用 Event 对象的 stopPropagation() 方法,可以阻止事件继续向上传播。 - 在事件处理函数中,返回 false 可以阻止事件继续向上传播。 以上是一些常见的拼多多前端面试题和答案,希望对您有所帮助!
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值