IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> 顺丰同城前端一面 -> 正文阅读

[JavaScript知识库]顺丰同城前端一面

顺丰同城前端一面

1.自我介绍

巴拉巴拉!~~~~

2.选择前端的理由

巴拉巴拉!~~~~

3.用css实现三角形

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>正三角形实现</title>
    <style>
      .triggle{
            width: 0px;
            height: 0px;
            border-top: 50px solid transparent;
            border-left: 50px solid transparent;
            border-bottom: 50px solid red;
            border-right: 50px solid transparent;
        }
    </style>
</head>
<body>
    <div class="triggle"></div>
</body>
</html>

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具体使用?

数据以<key,value>形式保存在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.新人培养计划

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

  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2022-11-05 00:19:49  更:2022-11-05 00:22:59 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/11 17:59:45-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码