Vue

Vue<路由加密传参>

2019-07-19  本文已影响9人  誰在花里胡哨

此处用到的是Base64加密,首先创建一个base64.js,代码如下

const Base64 = {
   //加密
    encode(str) {
        return btoa(encodeURIComponent(str).replace(/%([0-9A-F]{2})/g,
            function toSolidBytes(match, p1) {
                return String.fromCharCode('0x' + p1);
            }));
    },
  //解密
    decode(str) {
        // Going backwards: from bytestream, to percent-encoding, to original string.
        return decodeURIComponent(atob(str).split('').map(function (c) {
            return '%' + ('00' + c.charCodeAt(0).toString(16)).slice(-2);
        }).join(''));
    }
}
export default Base64

main.js中引入,方便调用

import Base64 from './assets/js/base64.js' 

Vue.prototype.$Base64 = Base64;

我这边用到的是通过路由的path进行传参,感觉加密的话用path传比较好,同时也方便其它端在调用你页面时,获取参数。

传参页面

 this.$router.push({
        path: "/PropertyDetails",
        query:{
          key:this.$Base64.encode(JSON.stringify({
            type:'',
            id: '',
            mobile:'',
            productId: '',
          }))
        }
      });

接收页面:

 let params = JSON.parse(this.$Base64.decode(this.$route.query.key))
上一篇 下一篇

猜你喜欢

热点阅读