vue路由的两种模式
Vue 路由模式 hash 和 history,简单讲一下Hash 模式地址栏中有#,history 没有,history 模式下刷新,会出现 404 情况,需要后台配置使用 JavaScript 来对 loaction.hash 进行赋值,改变 URL 的 hash值可以使用 hashchange 事件来监听 hash 值的变化HTML5 提供了 History API 来实现 URL 的变化。其中最主要的 API有以下两个:history.pushState() 和 history.repalceState()。这两个API 可以在不进行刷新的情况下,操作浏览器的历史纪录。唯一不同的是,前者是新增一个历史记录,后者是直接替换当前的历史记录
js数据类型
String、Number、Boolean、Null、Undefined、Symbol、BigInt
let const var 的区别
1. var和let作用都是用作声明变量,const声明一个常量,
2. var的声明是变量提升,能够作用于全局,而let和const作用于局部的
3. var是能够重复声明的而let和const是只能声明一次的
4. var和let的值在声明后是可以改变的,而const声明的常量是只读的不可改变,但对于对象和数据这种引用类型,内存地址不能修改,可以修改里面的值。
vue生命周期
beforeCreate(创建实例)
created(创建完成)、
beforeMount(开始创建模板)
mounted(创建完成)、
beforeUpdate(开始更新)
updated(更新完成)、
beforeDestroy(开始销毁)
destroyed(销毁完成)
created和mounted这两个生命周期中数据请求的区别
created是在组件实例一旦创建完成的时候立刻调用,这时候页面dom节点并未生成mounted是在页面dom节点渲染完毕之后就立刻执行的触发时机上created是比mounted要更早的两者相同点∶都能拿到实例对象的属性和方法讨论这个问题本质就是触发的时机,放在mounted请求有可能导致页面闪动(页面dom结构已经生成),但如果在页面加载前完成则不会出现此情况建议:放在create生命周期当中
数组去重
Set实现去重
let originalArray = [1,2,3,4,1,2,3,4]
let uniqueArray = array =>[...new Set( array) ]
// or
let uniqueArray = Array .from( new Set(originalArray))
// uniqueArray = [1,2,3,4]
深拷贝实现
function deepclone(obj) {
var target = {};
for (var key in obj) {
if (object.prototype.hasOwnProperty.call(obj, key)) {
if (typeof obj[ key] === 'object ' ) {
target[ key] = deepclone(obj[ key]);}else {
target[ key] = obj[ key];
}
}
}
return target;
}
标签:obj,五月,三十日,面试,let,key,var,const,mounted
From: https://www.cnblogs.com/mrkr/p/17444004.html