记录页面跳转传参不让地址出现传的参数,还要使页面刷新不丢失数据

一般来说,传参的方法也是有两种:query传参和params动态路由传参。

两者的区别:1.query传递显示参数,params传递不显示参数 2. query刷新页面数据不会丢失,params刷新页面会丢失数据。params相对于query来说较安全一点


现在,需求就是传参不让地址出现传的参数,还要使页面刷新不丢失数据。思路就是需要用到vuex,vuex不懂的,直接百度了解一下,现在废话多说,直接上


  1. 跳转按钮那里this.$store.dispatch传参,地址上就不会出现传递的参数,我需要传递的参数就是goLabdetailData
 goDetails(index, row, id, title) {
      this.$store.dispatch('pageData/setlabdetaildata', JSON.stringify(row))
      this.$router.push({ name: 'labDetails', params: { userId: this.id || undefined})
    },

2.  现在就是去vuex里面去写

const state = {
  labDetails: window.sessionStorage.getItem('labDetails')
}
const mutations = { 
  SET_LABDETAILDATA: (state, value) => {
    state.labDetails = value
    window.sessionStorage.setItem('labDetails', value)
  }
}
const actions = { 
  setlabdetaildata({ commit }, value) {
    commit('SET_LABDETAILDATA', value)
  }
}

export default {
  namespaced: true,
  state,
  mutations,
  actions
}

3. 去getter页面写

const getters = { 
  labDetails: state => state.pageData.labDetails
}

export default getters

4. 页面引入mapGetters,

 import { mapGetters } from 'vuex'


  computed: {    ...mapGetters([
    'labDetails'
    ])
  },
  created() {

    console.log("getsesstion",JSON.parse(this.labDetails))

  },

这样就能拿到值啦,刷新也不会丢失


总结

例如:就是用了store状态,把这个值用sesstionstorage缓存起来,getter获取存入state,页面使用mapgetter方法映射到计算属性中去。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值