顺丰同城前端一面
创始人
2024-04-03 21:34:58
0

顺丰同城前端一面

文章目录

  • 顺丰同城前端一面
      • 1.自我介绍
      • 2.选择前端的理由
      • 3.用css实现三角形
      • 4.垂直水平居中实现
      • 5.基本数据类型,引用数据类型
      • 6.数组操作方法
          • 1.forEach:遍历每个元素并处理。没有返回值
          • 2.map:遍历每个元素并处理。返回值为处理后的数组。原数 组不改变
          • 3.filter:根据条件筛选每个元素,默认返回数组。数组内为符合条件的值
          • 4.some,every:和filter类似,但返回值是boolean.
          • 5.reduce:可用作累加累乘
      • 7.call,bind,apply共同点和区别
      • 8.防抖节流实现,区别?应用场景?
      • 9.浅拷贝和深拷贝区别?实现?
      • 10.浏览器缓存数据方式?
      • 11.localstorage具体使用?
      • 12.vue的生命周期
      • 13.nextTick是什么?
      • 14.vue组件通信?
      • 16.介绍mixin?
      • 17.vue2和vue3区别?
      • 18.vue刷新如何实现数据缓存(vue持久化存储)
      • 19.微信小程序路由跳转方式
      • 20.微信小程序传递数据的方式
      • 21.作为项目负责人,最重要的是什么?
      • 22.实习最大的收获
      • 23.反问?

1.自我介绍

巴拉巴拉!~~~~

2.选择前端的理由

巴拉巴拉!~~~~

3.用css实现三角形



正三角形实现

4.垂直水平居中实现

参考这文章

5.基本数据类型,引用数据类型

1.基本类型:number、boolean、string、undefined、 null
2.引用类型:array、object、function、regexp…

6.数组操作方法

1.forEach:遍历每个元素并处理。没有返回值
计算大于1的个数
let arr=[1,2,3,4,5]
let res=0
arr.forEach(item=>{item>1?res++:res
})
console.log(res)//4
2.map:遍历每个元素并处理。返回值为处理后的数组。原数 组不改变
//每个元素值*2并返回
let arr=[1,2,3,4,5]
let res1=arr.map(item=>{return item*2
})
console.log(res1)//[ 2, 4, 6, 8, 10 ]
console.log(arr)//[ 1, 2, 3, 4, 5 ]
3.filter:根据条件筛选每个元素,默认返回数组。数组内为符合条件的值
let arr=[1,2,3,4,5]
let res2=arr.filter((item,index)=>{return item*index>3
}
)
console.log(res2)//[ 3, 4, 5 ]
4.some,every:和filter类似,但返回值是boolean.

every:当所有元素都符合条件,返回true。只有一个false放回false.

some:当有一个为true时,返回true.全部为false时,返回false

let arr=[1,2,3,4,5]
let  res3=arr.every((item,index)=>{return item*index>1
}
)let  res4=arr.some((item,index)=>{return item*index>3
}
)
console.log(res3)//false
console.log(res4)//true
5.reduce:可用作累加累乘
//val表示累计值,item(必填其他都可选填)当前值,index数组下标,0表示val初始值。
let arr=[1,2,3,4,5]
let  res5=arr.reduce((val,item,index)=>{return val+item*index
},0)
console.log(res5)//40

6.for-in for-of

let arr=[1,2,3,4,5]
for(i in arr)
{console.log(i)//下标01234
}for(i of arr)
{console.log(i)//数组值12345
}

7.call,bind,apply共同点和区别

共同点:改变this的指向
区别:

  1. call 后面的参数 可以分开传递
  2. apply后面的参数 放在一个数组中传递
  3. bind和apply传参类似 只是bind 返回的是一个函数 不会立即执行,需要调用

8.防抖节流实现,区别?应用场景?

9.浅拷贝和深拷贝区别?实现?

10.浏览器缓存数据方式?

在这里插入图片描述

11.localstorage具体使用?

数据以形式保存在localstorage内部,可以调用getItem或者setItem实现。

12.vue的生命周期

简单来说,就是组件从创建到撤销的过程。分为初始化,挂载,更新,销毁四个阶段。

初始化阶段:

beforeCreate创建前):初始化还未开始 ,不能访问data数据,computed,watch,methods等方法

created(创建后):初始化完成,可以获得data数据,设置好computed,watch,methods方法,不能访问dom节点。

挂载阶段:

beforeMount(挂载前):此时render函数被调用,生成虚拟dom树,还没挂载

mounted(挂载后):将虚拟dom挂载到真实的dom树上,此时可以访问dom节点。

更新阶段:

beforeUpdate(更新前):响应式数据更新了,但dom节点并未更新。此时还可以访问原有的dom节点

updated(更新后):根据diff算法,找出差异并把差异更新到真实的dom树 上。

销毁阶段:

beforeDestroy(销毁前):实例销毁前调用,此时还可以访问实例数据

destroyed(销毁后):实例销毁后调用,清除wacher,子组件,事件监听器等。


13.nextTick是什么?

解决问题:修改数据以后,无法立刻拿到最新的DOM节点对象

原理:异步DOM更新放在下一轮的事件循环当中,调用回调函数。拿到最新的dom节点。提高效率

具体:Vue是异步执行dom更新的,一旦观察到数据变化,Vue就会开启一个队列,然后把在同一个事件循环 (event loop)
当中观察到数据变化的 watcher
推送进这个队列。如果这个watcher被触发多次,只会被推送到队列一次。这种缓冲行为可以有效的去掉重复数据造成的不必要的计算和Dom操作。而在下一个事件循环时,Vue会清空队列,并进行必要的DOM更新

14.vue组件通信?

  • 子组件通过 props 属性来接受父组件的数据,然后父组件在子组件上注册监听事件,子组件通过 emit 触发事件来向父组件发送数据。
  • 通过 ref 属性给子组件设置一个名字。父组件通过 $refs 组件名来获得子组件,子组件通过 $parent 获得父组件,这样也可以实现通信。
  • 使用 provide/inject,在父组件中通过 provide提供变量,在子组件中通过 inject 来将变量注入到组件中。不论子组件有多深,只要调用了 inject 那么就可以注入 provide中的数据。
  • 使用 eventBus 的方法,它的本质是通过创建一个空的 Vue 实例来作为消息传递的对象,实例上监听和触发事件,来实现消息的传递。

16.介绍mixin?

参考大佬博文
当组件使用混入对象时,该组件可调用混入对象的函数,属性。相当于给组件扩展功能的作用
分为三种

  1. 局部混入

被混入的的组件可调用混入对象的钩子函数或者属性值,如creacted,

  1. 选项合并

当组件和混入对象含有同名选项时,冲突时以组件数据优先。如果组件和对象同时存在钩子函数,先执行混入对象的钩子函数

  1. 全局混入

一旦使用全局混入,它将影响每一个之后创建的 Vue 实例。相当于给Vue每个组件混入了对象。

17.vue2和vue3区别?

  • 数据绑定原理:object.definedProperty和proxy区别
  • 生命周期区别
  • Vue3支持碎片(Fragments)
  • 数据和方法的定义:vue2定义在data内,vue3定义在setup()内

18.vue刷新如何实现数据缓存(vue持久化存储)

  1. 利用vuex-persistedstate插件,可自行设置默认存储类型:localstorage,sessionstorage,cookie
  2. 使用localStorage在数据存储

19.微信小程序路由跳转方式

1.wx.navigateTo():保留当前页面,跳转到应用内的某个页面。但是不能跳到 tabbar 页面

2.wx.redirectTo():关闭当前页面,跳转到应用内的某个页面。但是不允许跳转到 tabbar 页面

3.wx.switchTab():
跳转到 tabBar 页面,并关闭其他所有非 tabBar 页面(不可以携带参数)

4.wx.navigateBack()
关闭当前页面,返回上一页面或多级页

5.wx.reLaunch():关闭所有页面,打开到应用内的某个页面

20.微信小程序传递数据的方式

1.使用全局变量 app.globalData

2.使用本地缓存 wx.setStorageSync
3.url传递

21.作为项目负责人,最重要的是什么?

负责,展开说说~~~~,又是巴拉巴拉

22.实习最大的收获

巴拉巴拉~

23.反问?

1.公司工作时间
2.新人培养计划

大部分回答出来了,期待二面

相关内容

热门资讯

吉利起诉欣旺达,理想汽车躺枪? 想象一下,我从你这里采购电池,还替你宣传,结果因为你的质量问题让大家质疑我,这是一种什么感受? 1...
獐子岛:近12个月新增累计诉讼... 12月29日,獐子岛(002069)发布公告,截止到公告披露日,公司及控股子公司在最近十二个月内累计...
政策迎重大调整!概念股集体飙涨... 12月29日,A股市场主要股指震荡走势,沪指收盘微涨0.04%,录得九连阳。从板块上来看,数字人民币...
福石控股累计诉讼仲裁1792万... 12月29日,福石控股(300071)发布公告,截至公告披露日前,公司及子公司在过去十二个月内的累计...
犯罪收益达14.6亿韩元,享有... 金建希利用总统夫人身份,收受大量财物,并广泛介入了各种人士安排,“甚至可以称得上是现代卖官卖职”,韩...
金评天下丨“长钱长投”制度环境... 金融投资报评论员 刘柯 中国人民银行于12月26日发布《中国金融稳定报告(2025)》(以下简称《金...
偷拿自己快递再退款不是“薅羊毛... 网购下单付款,待快递到站后秘密取走,再以“未收到货”申请退款,这样的行为看似钻了“空子”,实则已触犯...
全球瞭望丨美媒集体抨击特朗普政... 新华社洛杉矶12月28日电(记者黄恒)美国加利福尼亚州多家地方媒体28日集体刊登同一篇社论,抨击特朗...
一个假律师凭啥“拿捏”酒企? ... 打着“维权”的幌子,干着敲诈的勾当,事后还要签订“法律服务”合同……江苏宿迁一名假律师专门敲诈酒企,...