在vue中 storge 和vuex使用的用法区别

10 篇文章 0 订阅
在vue中 storge 和vuex使用的用法区别

1.联动性:storge对于属性的改变不能触发其他页面的改动

  • storage: 存取login之后就不会改变的信息,比如userId, isAdmin(是否是管理员)
  • vuex: 存取login之后可能在某个组件会改变的信息, 比如isInMyPort,isInPort

比如:
我在A页面改了userInfo 不经过刷新。b对他的调用并不知道最新的改动

实际运用:
在 渔港项目中 权限管理,每个页面显示当前港口,切换至别的港口,开放首页权限;并且关闭其他所有界面。这就是一个组件操控另外一个好远的组件,这里必须使用vuex, 但是刷新当前界面,要保留当前港口信息。这一块要用storage,故需要storage和vuex结合使用;

  • location.vue
    1.在每次刷新的时候从storage取出信息
    2.切换港口的时候提交mutation并且更新storage
  • cache/UserInfo.vue
    存取用户所有信息

code

storage:
{
    //用户信息接口返回的信息
    createTime: "2019-05-07 17:45:51"
    createUserId: 1
    email: "1@1.com"
    userId: 1
    userType: 3
    username: "admin"
    mobile: "11111111111"
    orgId: "0"
    orgName: "深圳"
    password: "xxx"
    realName: "超级管理员"
    roleIdList: null
    salt: "xxx"
    status: 1

    // 系统里面根据需要‘计算’出的信息
    isAdmin: true
    isInMyPort: true
    isInPort: true
    currentOrg: {title: "蛇口渔港", id: 1001, parentId: 100, orgType: 2, mainOrg: 0, orgName: "蛇口渔港", waterArea: "29万㎡",…}
    orgList: [,…]
}

vuex:
const state = {
    //是否在自己的港口
    isInMyPort: true,
    //当前用户 是在港口 还是在深圳海域
    isInPort: true
}





  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值