2021-07-15 表单校验-ElementUI

一. 表单校验的先决条件

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

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

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

3.<el-input />标签用v-model 绑定数据对象中相对应的数据。

<el-input  v-model="loginForm.mobile"> </el-input>

二、表单校验规则

规则 说明
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 {}
}

第一个参数代表当前的校验规则。
第二个参数代表当前被校验的数据。
第三个参数是一个回调函数。注意:无论是否通过校验,都要调用callback()函数。

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

四、手动校验

1.什么是手动校验

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

2.如何实现手动校验

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

① 给<el-form> 标签设置 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
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,547评论 6 477
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,399评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,428评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,599评论 1 274
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,612评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,577评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,941评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,603评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,852评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,605评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,693评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,375评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,955评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,936评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,172评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 43,970评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,414评论 2 342

推荐阅读更多精彩内容