时隔半年,重新面试(复习曾经会但忘记的)

localStorage 和 sessionStorage 的区别

localStorage和sessionStorage所使用的方法是一样的,下面以sessionStorage为栗子:

ini 复制代码
var name='sessionData';
var num=120;
sessionStorage.setItem(name,num);//存储数据
sessionStorage.setItem('value2',119);
let dataAll=sessionStorage.valueOf();//获取全部数据
console.log(dataAll,'获取全部数据');
var dataSession=sessionStorage.getItem(name);//获取指定键名数据
var dataSession2=sessionStorage.sessionData;//sessionStorage是js对象,也可以使用key的方式来获取值
 console.log(dataSession,dataSession2,'获取指定键名数据');
sessionStorage.removeItem(name); //删除指定键名数据
  console.log(dataAll,'获取全部数据1');
 sessionStorage.clear();//清空缓存数据:localStorage.clear();
  console.log(dataAll,'获取全部数据2');  

两者区别

  1. localStorage和sessionStorage的差别一个是永久保存在浏览器里面,一个是关闭网页就清除了信息。

  2. localStorage可以用来跨页面传递参数,sessionStorage则不可以。origin(源)相同的页面,sessionStorage是无法传递的。

  3. sessionStorage用来保存一些临时的数据,防止用户刷新页面之后丢失了一些参数。

Promise相关原理

promise中有三种状态

  • pending
  • fufilled
  • rejected

当 pending -> fufilled 或者 pending -> rejecte 状态改变后,状态就无法再变化了。

常见的promiseAPI

  • Promise.all

接收一个 promise数组,当所有promise都是成功状态,则返回一个成功状态的数组,否则当其中一个promise执行失败,则会catch 第一个执行失败的promise ,并返回原因。

  • Promise.allSettled

与all方法很像,不同的是,不会因为其中一个promise 失败了,就停止执行,而是等所有promise都完成后,方法携带promise状态的数组。

如下:

lua 复制代码
[
  { status: 'fulfilled', value: 3 },
  { status: 'rejected', reason: 'foo' }
]
  • Promise.race

接受一个 promise 数组,返回第一个完成(无论失败还是成功)

有点类似于赛马,看哪匹马跑得最快(哈哈哈)

相关推荐
samuel9182 分钟前
pinia实现数据持久化插件pinia-plugin-persist-uni
前端·vue
谢一歇_fn3 分钟前
如何在uni-app中自定义输入框placeholder的样式
前端·javascript·uni-app
ganshenml8 分钟前
【Web】如何解决 `npm run dev` 报错 `address already in use 127.0.0.1:9005` 的问题
前端
顽强d石头14 分钟前
elementui里的el-tabs的内置样式修改失效?
前端·javascript·elementui
江湖行骗老中医38 分钟前
js闭包概念和使用
开发语言·javascript·ecmascript
king1999010241 分钟前
小程序Npm package entry file not found?
前端·npm·node.js
程序猿阿伟1 小时前
《解锁CSS Flex布局:重塑现代网页布局的底层逻辑》
前端·css
生产队队长1 小时前
CSS:选择器-复合选择器
前端·css
黄同学real1 小时前
前端安全中的XSS(跨站脚本攻击)
前端·安全·xss
楠奕1 小时前
Neo4j多关系或多路径
前端·javascript·neo4j