uniapp小程序开发,判断跳转页面是否需要登录方法封装

方法工具,放置在 tool.js文件中

javascript 复制代码
/**
 * @params { Object } params 路由参数
 * @desc 将路由参数拼接成字符串
 */
export function queryStr(params) {
  const paramsArr = []
  if (params) {
    for (const k in params) {
      const str = `${k}=${params[k]}`
      paramsArr.push(str)
    }
  }
  let paramsStr = ''
  if (paramsArr.length > 0) {
    paramsStr += '?'
    paramsStr += paramsArr.join('&')
  }
  return paramsStr
}
/**
 * @path { String } 跳转路径
 * @data { Object } 路由参数
 * @permission { Object } 是否校验登录态
 * @desc 路由跳转登录态校验、参数拼接
 */
export function goToPage(path: string, data, permission: { needLogin: boolean; msg?: string }) {
  const user = uni.getStorageSync('user')
  let userInfo = {}
  if (user) {
    userInfo = JSON.parse(user)?.userInfo
  }
  // console.log('用户登录信息userInfo:', userInfo)
  const { needLogin, msg } = permission || {}
  if (!userInfo?.agentId && needLogin) {
    uni.showModal({
      title: '温馨提示',
      content: msg || '您需要登录后才能进行下一步操作,是否去登录',
      cancelText: '取消',
      confirmText: '去登录',
      success: function (res) {
        if (res.confirm) {
          uni.navigateTo({
            url: '/pages/login/index',
          })
        } else if (res.cancel) {
          console.log('用户点击取消')
        }
      },
    })
    return
  }
  uni.navigateTo({
    url: path + queryStr(data),
  })
}

使用

javascript 复制代码
import { goToPage} from '@/utils/tool'

goToPage('/pages/personal/index', null, { needLogin: true })
相关推荐
jiayu21 分钟前
Angular学习笔记24:Angular 响应式表单 FormArray 与 FormGroup 相互嵌套
前端
jiayu22 分钟前
Angular6学习笔记13:HTTP(3)
前端
小码哥_常25 分钟前
Kotlin抽象类与接口:相爱相杀的编程“CP”
前端
evelynlab26 分钟前
Tapable学习
前端
进击的尘埃28 分钟前
Vue3 响应式原理:从 Proxy 到依赖收集,手撸一个迷你 reactivity
javascript
willow40 分钟前
JavaScript数据类型整理1
javascript
LeeYaMaster40 分钟前
15个例子熟练异步框架 Zone.js
前端·angular.js
evelynlab43 分钟前
打包原理
前端
LeeYaMaster1 小时前
20个例子掌握RxJS——第十一章实现 WebSocket 消息节流
javascript·angular.js
拳打南山敬老院1 小时前
Context 不是压缩出来的,而是设计出来的
前端·后端·aigc