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 })
相关推荐
吃好睡好便好6 小时前
用while循环语句求和
开发语言·学习·算法·matlab·信息可视化
TechWayfarer6 小时前
查询IP所在地的3种方案:从API到离线库,风控场景怎么选?
开发语言·网络·python·网络协议·tcp/ip
摇滚侠6 小时前
Java 零基础全套教程,集合框架,笔记 153-163
java·开发语言·笔记
程序员榴莲6 小时前
Python 单例模式
开发语言·python·单例模式
L、2187 小时前
CANN算子开发调试实战:从“Segmentation Fault“到定位根因的完整流程
java·开发语言
狗凯之家源码网7 小时前
基于PHP的多语言跨境电商B2B2C商城系统技术解析
开发语言·php
Hyyy8 小时前
普通前端续命周报——第1周
前端·javascript
比特森林探险记8 小时前
go 语言中的context 解读和用法
开发语言·后端·golang
古城小栈8 小时前
Rust 调用 C 语言库 实战指南(企业级)
c语言·开发语言·rust
KaMeidebaby8 小时前
卡梅德生物技术快报|抗独特型抗体开发:半抗原检测技术瓶颈拆解,抗独特型抗体开发工程化实践
前端·数据库·人工智能·其他·百度·新浪微博