JavaScript - localStorage的增删改查

前言

localStorage简介

  • localStorage是浏览器用来进行本地存储数据的,用于解决cookie存储能力不足的情况;

localStorage与cookie的区别:

  • cookie存储的数据大小被限制为4k,localStorage存储的数据可达到5M;

localStorage与sessionStorage的区别:

  • localStorage属于永久性储存,sessionStorage存储的数据在会话结束后会自动清空;
  • 浏览器限制localStorage的值类型为string类型,如果存储的数据不是string类型,localStorage会自动对数据进行类型转换;

解决方法

1、増和改:

window.localStorage.setItem(key, value);
window.localStorage[key] = value;
window.localStorage.key = value;

2、查:

let value = window.localStorage.getItem(key);
let value = window.localStorage[key];
let value = window.localStorage.key;

3、删:
localStorage的删除分为两种:一种是删除全部localStorage数据;一种是删除localStorage中的某一条数据;

//全部删除方法
window.localStorage.clear();
//删除某一条数据的方法:
window.localStorage.removeItem(key);

4、需要注意的是:

  • 浏览器限制localStorage的值类型为string类型,如果存储的数据不是string类型,localStorage会自动对数据进行类型转换;
  • 存储的Json对象数据时,需要使用JSON.stringify()方法将数据转换成Json字符串,读取时,使用JSON.parse()将Json字符串还原回去;
Vue3中的Vuex是一个状态管理模式,特别适合于管理全局组件之间的共享状态。当涉及到数据的增删改查操作时,我们可以结合Vuex使用: 1. **增**: 新建一个mutation(改变状态的动作)用于添加新的数据项。例如: ```javascript mutations: { ADD_ITEM(state, item) { state.items.push(item); } } ``` 然后在组件中通过dispatch触发这个mutation。 2. **删**: 另一个mutation处理删除操作,通常会接受一个id作为参数: ```javascript mutations: { DELETE_ITEM(state, id) { state.items = state.items.filter(item => item.id !== id); } } ``` 3. **改**: 同样创建一个mutation更新特定的数据: ```javascript mutations: { UPDATE_ITEM(state, updatedItem) { const index = state.items.findIndex(item => item.id === updatedItem.id); if (index !== -1) { state.items[index] = updatedItem; } } } ``` 4. **查**: 数据获取通常通过actions(异步操作),如axios请求API: ```javascript actions: { fetchItems({ commit }) { axios.get('/api/items').then(response => { commit('SET_ITEMS', response.data); }); } } ``` 最后,在组件中使用`mapActions`映射这个action到store。 至于本地存储,Vue提供了一些库如vue-local-storage、quasar-framework等,可以将Vuex的状态持久化。例如,保存数据前: ```javascript beforeDestroy() { localStorage.setItem('items', JSON.stringify(this.$store.state.items)); } ``` 恢复时: ```javascript created() { try { const storedItems = JSON.parse(localStorage.getItem('items')); this.$store.commit('SET_ITEMS', storedItems); } catch (error) {} } ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值