2021-07-15 表单校验-ElementUI

一. 表单校验的先决条件

  1. 标签用v-bind:model绑定数据对象。:rules绑定校验规则对象。

注意: model是表单的属性,用v-bind绑定。这跟 v-model不是一回事!!!!!!!!!


data () {
    return {
      // 表单绑定的数据对象
      loginForm: {
        // 校验的字段
        mobile: '',
        password: ''
      },
      // 表单绑定的校验规则对象
      loginRules: {
        mobile: [],
        password:[]
    }
  },
  1. 标签设置 prop属性。值为 数据对象中的校验字段
 

3.标签用v-model 绑定数据对象中相对应的数据。

 

二、表单校验规则

规则 说明
required 如果为true,表示该字段为必填
message 当不满足设置的规则时的提示信息
pattern 正则表达式,通过正则验证值
min 当值为字符串时,min表示字符串的最小长度,当值为数字时,min表示数字的最小值
max 当值为字符串时,max表示字符串的最大长度,当值为数字时,max表示数字的最大值
trigger 校验的触发方式,change(值改变) / blur (失去焦点)两种
validator 如果配置型的校验规则不满足你的需求,你可以通过自定义函数来完成校验

格式:

loginRules:{
 校验字段:[ { },{ },{ } ]
}

 loginRules: {
        mobile: [{
          required: true, message: '手机号不能为空', trigger: 'blur'
        },
        { pattern: /^1[3-9]\d{9}$/, message: '手机号格式不正确', trigger: 'blur' }],
    }

三、自定义校验规则

  1. validator是一个函数,可以定义在 data 中。
data () {
    // 自定义校验规则
    const checkMobile = function (rulue, value, callback) {
      value.charAt(2) === '0' ? callback() : callback(new Error('错误'))
    }
    return {}
}

第一个参数代表当前的校验规则。
第二个参数代表当前被校验的数据。
第三个参数是一个回调函数。

  1. 自定义校验规则的函数定义好之后,要在规则对象中引用。
loginRules: {
     mobile: [{ validator: checkMobile, message: '手机号第三位必须是0', trigger: 'blur' }]
}

四、手动校验

1.什么是手动校验

① 以上校验只能在表单失去焦点或者内容变化时触发。
② 现在希望点击登录按钮时对所有表单项进行校验。或者对部分表单进行校验。

2.如何实现手动校验

element-ui提供了表单校验的API,我们需要通过 this.$refs 拿到表单的 DOM对象,来调用API函数。

① 给 标签设置 ref 属性。。
② 给提交按钮绑定点击事件。
③ 在事件函数中,给表单对象绑定 validate()函数,进行校验。

methods: {
    // 手动校验
    submitForm () {
      this.$refs.loginFormRef.validate()
        .then(() => console.log('校验成功'))
        .catch((error) => console.log('校验失败'))
    }
  }
3. element-ui 提供的表单校验API
方法名 说明 参数
validate 对整个表单进行校验的方法,参数为一个回调函数。该回调函数会在校验结束后被调用,并传入两个参数:是否校验成功和未通过校验的字段。若不传入回调函数,则会返回一个 promise Function(callback: Function(boolean, object))
validateField 对部分表单字段进行校验的方法 Function(props: array | string, callback: Function(errorMessage: string))
resetFields 对整个表单进行重置,将所有字段值重置为初始值并移除校验结果
clearValidate 移除表单项的校验结果。传入待移除的表单项的 prop 属性或者 prop 组成的数组,如不传则移除整个表单的校验结果 Function(props: array | string)

(1)validate可以传入一个函数作为参数,判断是否校验成功;也可以使用promise的.then().catch()方法。
(2)上面使用的是promise方法。下面是传入回调函数的方法。

this.$refs.loginFormRef.validate((boolean,object)=>{} )
形参boolean的值可以判断校验是否成功;形参object时未通过校验的字段。

五、其他

1. vue.cli的webpack反向代理

(1)为什么存在跨域?
当下,最流行的就是前后分离项目,也就是前端项目和后端接口并不在一个域名之下,那么前端项目访问后端接口必然存在跨域的行为。

(2)跨域分几种情况?
跨域分为 开发环境的跨域生产环境的跨域。前端人员在本地开发,与后端接口存在跨域;上线后,项目在腾讯、百度的服务器上,与后端接口也存在跨域。

(3)如何解决开发环境的跨域?
开发环境的跨域,也就是在vue-cli脚手架环境下开发启动服务时,我们访问接口所遇到的跨域问题,vue-cli为我们在本地开启了一个服务,可以通过这个服务帮我们代理请求,解决跨域问题。也就是用本地服务的后端去请求其他服务器的后端接口。

(4)具体配置。

module.exports = {
  devServer: {
   // 代理配置
    proxy: {
        // 这里的api 表示如果我们的请求地址有/api的时候,就出触发代理机制
        // localhost:8888/api/abc  => 代理给另一个服务器
        // 本地的前端  =》 本地的后端  =》 代理我们向另一个服务器发请求 (行得通)
        // 本地的前端  =》 另外一个服务器发请求 (跨域 行不通)
        '/api': {
        target: 'www.baidu.com', // 我们要代理的地址
        changeOrigin: true, // 是否跨域 需要设置此值为true 才可以让本地服务代理我们发出请求
         // 路径重写
        pathRewrite: {
            // 重新路由  localhost:8888/api/login  => www.baidu.com/api/login
            '^/api': '' // 这样可以把 localhost:8888/api/login 变成www.baidu.com/login      
        }
      },
    }
  }
}

① 在vue.config.js配置文件中,添加反向代理的配置内容----> proxy对象。

② api:自定义的需要代理的地址。当项目请求后端接口时,如果地址里包含 api 字段,就会 触发代理机制。

③ target:跨域请求的地址,也就是从哪个后端地址请求数据。不需要加api字段,代理请求时会默认添加。

④ changeOrigin:是否跨域。值为true时,才能让本地服务的后端代替我们发出请求。

⑤ pathRewrite:重写路径。可以把请求地址中不需要的部分替换。

注意:配置好反向代理后,axios的基础地址直接写 api 即可 。

  1. 组件库中,组件的 属性、事件、方法。v-bind 、v-on 、this.$refs

你可能感兴趣的:(2021-07-15 表单校验-ElementUI)