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 })
相关推荐
kyriewen1 分钟前
Anthropic 估值逼近万亿美元,Claude Sonnet 5 + Claude Science 一天两连发
前端·ai编程·claude
小徐_23331 小时前
Wot UI 2.2.0 发布:Button 新增 subtle,VideoPreview 预览体验继续增强
前端·微信小程序·uni-app
山河木马3 小时前
矩阵专题3-怎么创建投影矩阵(uProjectionMatrix)
javascript·webgl·计算机图形学
天蓝色的鱼鱼4 小时前
关于 CSS 你可能不知道的属性,但关键时刻很有用
前端·css
泯泷5 小时前
第 2 篇:设计第一套字节码:Opcode、Instruction 与 Constant Pool
前端·javascript·安全
妙码生花5 小时前
从 PHP 到 AI + Golang,程序员自救转型手记(十五):优化细节、网络请求封装
前端·后端·ai编程
泯泷5 小时前
第 1 篇:从 1 + 2 开始:亲手写出第一台 JSVM
前端·javascript·安全
团团崽_七分甜5 小时前
Spring Boot 核心知识点总结
前端
lichenyang4535 小时前
从一个按钮开始,理解 ASCF 框架到底在做什么
前端