vue常问面试题

这篇博客主要涵盖Vue面试中常见的问题,包括CSS、JS、Vue框架的相关面试题。内容涉及v-model原理、组件data为何写成函数、scope样式私有化、v-if与v-show的区别、数据非响应式处理、组件封装、路由懒加载、axios封装、Vue响应式原理、项目优化、生命周期、公共组件封装、防抖节流、Vuex数据丢失解决方案、ES6新特性等核心知识点。
摘要由CSDN通过智能技术生成

css(面试题)

实现垂直居中的方式:

  1. flex布局:设置父元素为display:flex; 使用 justify-content:center; align-item:center;来进行居中
  2. 块级盒子使用:margin: 0 auto;
  3. 行内元素:使用: text-align:center line-height:父级高度
  4. 使用位移:transform: translate(50%,50%)
  5. 使用定位:子绝父相 来进行定位

pc端如何实现响应式布局:

  1. 可以通过px和rem的转换来进行
  2. 在vue中可以通过插件postcss-pxtorem px2rem-loader lib-flexible来进行
  3. 通过 vh vw %来进行 媒体查询

js(面试题)

ES6的都有哪些新特征呢?

  1. let和const
    let和const: 不存在变量提升;只能声明一次,不能重复声明; 遇到大括号会有块级作用域;
    变量声明出来存在VO或者AO,不会给window中增加属性。
    var: 有变量提升 在全局中声明的变量,会给window增加一个属性
  2. 实现了数组的结构赋值和对象的结构赋值
  3. 展开运算符
  4. map和set和filter
    map和filter的区别是 :map是会进行改变原数组的,而filter的话,只是进行元素的筛选,不会改变元素的个数。
    5箭头函数
    6模板字符串

深拷贝和浅拷贝都有哪些? 区别是什么?
浅拷贝:

1.Object.assign() :把两个对象合并成一个对象。
如果使用Object.assign()也算是只有一层算是深拷贝。
有子级的情况下是算浅拷贝。
2展开运算符:进行的就是浅拷贝
3slice()
4concat() 方法也算是浅拷贝
使用concat来进行对象的话是一个深拷贝
深拷贝
1JSON.stringify()或者JSON.parse
用json会出现的问题: 它不可以拷贝 undefined , function, RegExp等类型。
2通过for in
3递归
4concat(数组的深拷贝) 使用concat合并数据,会返回一个新的数组。

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值