当前位置:首页 > uni-app

uniapp全局校验

2026-02-05 20:15:13uni-app

全局校验的实现方式

在UniApp中实现全局校验通常涉及表单验证、请求拦截或路由守卫等场景。以下是几种常见的全局校验方法:

表单全局验证

使用uni-forms组件结合自定义校验规则实现表单全局验证:

// main.js 中注册全局校验规则
import Vue from 'vue'
Vue.prototype.$rules = {
  required: (value, callback) => {
    if (!value) {
      callback(new Error('必填项'))
    } else {
      callback()
    }
  },
  mobile: (value, callback) => {
    if (!/^1[3-9]\d{9}$/.test(value)) {
      callback(new Error('手机号格式错误'))
    } else {
      callback()
    }
  }
}

页面中使用:

uniapp全局校验

<uni-forms :rules="rules" ref="form">
  <uni-forms-item name="username" label="用户名">
    <input v-model="formData.username"/>
  </uni-forms-item>
</uni-forms>
export default {
  data() {
    return {
      rules: {
        username: {
          rules: [{
            required: true,
            errorMessage: '请输入用户名'
          }]
        }
      }
    }
  }
}

请求拦截校验

通过修改uni.request实现请求前的全局校验:

const originalRequest = uni.request
uni.request = function(options) {
  // 添加token校验
  if (!getToken() && !options.noAuth) {
    uni.showToast({ title: '请先登录', icon: 'none' })
    return Promise.reject('未授权')
  }

  // 添加公共参数
  options.header = options.header || {}
  options.header['X-Token'] = getToken()

  return originalRequest(options)
}

路由拦截校验

使用uni.addInterceptor实现页面跳转前的全局校验:

uniapp全局校验

// 在App.vue的onLaunch中添加
uni.addInterceptor('navigateTo', {
  invoke(args) {
    if (args.url.includes('/member/') && !isLogin()) {
      uni.showModal({
        title: '提示',
        content: '请先登录',
        success(res) {
          if (res.confirm) {
            uni.navigateTo({ url: '/pages/login/login' })
          }
        }
      })
      return false
    }
    return true
  }
})

全局混入校验方法

通过Vue.mixin添加全局校验方法:

Vue.mixin({
  methods: {
    $validateForm(refName) {
      return new Promise((resolve, reject) => {
        this.$refs[refName].validate().then(res => {
          resolve(res)
        }).catch(err => {
          uni.showToast({
            title: err[0].errorMessage,
            icon: 'none'
          })
          reject(err)
        })
      })
    }
  }
})

页面中使用:

async submit() {
  try {
    await this.$validateForm('formRef')
    // 验证通过后的逻辑
  } catch {
    // 验证失败
  }
}

注意事项

  1. H5端路由拦截可能受限,需配合后端校验
  2. 小程序端部分API拦截可能无效,需使用官方提供的拦截方式
  3. 复杂校验建议使用第三方库如vee-validateasync-validator
  4. 全局混入需注意方法命名冲突问题

根据项目实际需求选择合适的全局校验方案,通常建议组合使用多种方式实现完整的校验体系。

标签: 全局uniapp
分享给朋友:

相关文章

uniapp组件

uniapp组件

uniapp组件基础概念 uniapp的组件系统基于Vue.js,支持跨平台开发(H5、小程序、App等)。组件分为内置基础组件(如<view>、<button>)和自定义组件…

uniapp 录像

uniapp 录像

uniapp 录像功能实现 在uniapp中实现录像功能可以通过调用uni-app的API或结合第三方插件完成。以下是常见的实现方法: 使用uni.chooseVideo方法 uni.choose…

uniapp 滑动

uniapp 滑动

uniapp 实现滑动效果的方法 在uniapp中实现滑动效果可以通过多种方式,包括使用内置组件、CSS动画或第三方插件。以下是几种常见的方法: 使用scroll-view组件 scroll-vi…

uniapp 气泡

uniapp 气泡

uniapp 气泡实现方法 在 uniapp 中实现气泡效果可以通过多种方式,以下是常见的几种方法: 使用 CSS 样式实现气泡 通过 CSS 的 border 和 ::after 伪元素可以创建气…

uniapp真垃圾

uniapp真垃圾

关于对UniApp的评价,存在不同的声音。以下从技术特性、适用场景及常见争议点展开分析,供开发者参考: 技术特性与优势 UniApp基于Vue.js框架,支持多端编译(微信小程序、H5、App等),…

uniapp 成功案例

uniapp 成功案例

成功案例概览 UniApp 凭借跨平台开发能力,已被多个行业采用,涵盖电商、社交、教育、政务等领域。以下为部分典型案例: 京东拼购 京东拼购(现为“京喜”)采用 UniApp 开发,实现微信小程序、…