Vue Form表单的使用,rules格式校验网络校验,键盘按键监听

Form表单

rules格式校验

  • 可以在validator中进行网络请求,实现网络校验
js 复制代码
const formRules = {
  userName: [{required: true, message: "用户名不能为空", trigger: 'blur'}, {
    min: 5,
    max: 10,
    message: "长度必须5-10位",
    trigger: 'blur'
  }],
  passWord: [{required: true, message: "密码不能为空", trigger: 'blur'}],
  reference: [{
    validator: referenceValidity,
    required: true,
    trigger: "blur",
  },],
}

function referenceValidity(rule, value, callback) {
  console.log('校验推荐人')
  if (value === "" || value === undefined) {
    callback(new Error("请输入推荐人姓名"));
  } else {
    //请求网络校验推广人
    // console.log("输入的推荐人姓名:" + value)
    // const _url = "xxxxxxxxxxx";
    // let param = {};
    // param.promotionPecialistName = value;
    // get(this.$http, _url, param).then(function (response) {
    //   let res = response.data;
    //   if (res.code === "I000000") {
    //     if (res.data.isFlag) {
    //       callback()
    //     } else {
    //       callback(new Error("推荐人不存在"))
    //     }
    //   } else {
    //     callback(new Error("推荐人不存在"))
    //   }
    // });

    callback(new Error("推荐人不存在"))
  }
}

formRef引用form对象

  • form表单中关联formRef(引用对象),form(表单内容),formRules(校验规则)
js 复制代码
<el-form ref="formRef" :model="form" :rules="formRules">
js 复制代码
const formRef = ref()

function reqLogin() {
  console.log("账号信息", form.value)
  formRef.value.validate((valid) => {
    console.log("formRef valid = ", valid)
    if (valid) {
      setToken()
      store.commit("setUserInfo", form.value)
      showToast("登录成功")
      router.push('/')
    }
  })
}

键盘监听

js 复制代码
onMounted(() => {
  console.log("页面加载")
  document.addEventListener('keyup', onkeyup)
})

onBeforeUnmount(() => {
  document.removeEventListener('keyup', onkeyup)
})

function onkeyup(e) {
  if (e.key === 'Enter') {
    reqLogin()
  }
}

完整代码

js 复制代码
<script setup>

import {onBeforeUnmount, onMounted, ref} from "vue";
import {Lock, User} from "@element-plus/icons-vue";
import {useRouter} from "vue-router";
import {setToken} from "../utils/CookieUtil.js";
import {showToast} from "../utils/ToastUtil.js";
import {useStore} from "vuex";

const router = useRouter()
const store = useStore()

const form = ref({
  userName: "",
  passWord: "",
  reference: ""
})

const formRef = ref()

const formRules = {
  userName: [{required: true, message: "用户名不能为空", trigger: 'blur'}, {
    min: 5,
    max: 10,
    message: "长度必须5-10位",
    trigger: 'blur'
  }],
  passWord: [{required: true, message: "密码不能为空", trigger: 'blur'}],
  reference: [{
    validator: referenceValidity,
    required: true,
    trigger: "blur",
  },],
}

function referenceValidity(rule, value, callback) {
  console.log('校验推荐人')
  if (value === "" || value === undefined) {
    callback(new Error("请输入推荐人姓名"));
  } else {
    //请求网络校验推广人
    // console.log("输入的推荐人姓名:" + value)
    // const _url = "xxxxxxxxxxx";
    // let param = {};
    // param.promotionPecialistName = value;
    // get(this.$http, _url, param).then(function (response) {
    //   let res = response.data;
    //   if (res.code === "I000000") {
    //     if (res.data.isFlag) {
    //       callback()
    //     } else {
    //       callback(new Error("推荐人不存在"))
    //     }
    //   } else {
    //     callback(new Error("推荐人不存在"))
    //   }
    // });

    callback(new Error("推荐人不存在"))
  }
}

function onkeyup(e) {
  if (e.key === 'Enter') {
    reqLogin()
  }
}

onMounted(() => {
  console.log("页面加载")
  document.addEventListener('keyup', onkeyup)
})

onBeforeUnmount(() => {
  document.removeEventListener('keyup', onkeyup)
})

function reqLogin() {
  console.log("账号信息", form.value)
  formRef.value.validate((valid) => {
    console.log("formRef valid = ", valid)
    if (valid) {
      setToken()
      store.commit("setUserInfo", form.value)
      showToast("登录成功")
      router.push('/')
    }
  })
}

</script>

<template>
  <div style="height: 100vh;width: 100vw;display: flex;flex-direction: row">

    <div class="flex-col-center" style="width: 70%;height: 100%;background: #213547;">
      <span style="font-size: 40px;color: white;">测试系统登录页面</span>
      <span style="font-size: 20px;color: white;">演示Demo</span>
    </div>

    <div class="flex-col-center" style="width: 30%;padding: 100px">
      <h2 style="font-size: 20px">欢迎回来</h2>
      <el-form ref="formRef" :model="form" :rules="formRules">
        <el-form-item label="账号" prop="userName">
          <el-input v-model="form.userName" placeholder="请输入账号">
            <template #prefix>
              <el-icon>
                <User/>
              </el-icon>
            </template>
          </el-input>
        </el-form-item>
        <el-form-item label="密码" prop="passWord">
          <el-input v-model="form.passWord" placeholder="请输入密码" show-password type="password">
            <template #prefix>
              <el-icon>
                <Lock/>
              </el-icon>
            </template>
          </el-input>
        </el-form-item>
        <el-form-item label="推荐人" prop="reference">
          <el-input v-model="form.reference" placeholder="请输入推荐人"></el-input>
        </el-form-item>
      </el-form>
      <el-button type="primary" @click="reqLogin()">登录</el-button>
    </div>

  </div>
</template>

<style scoped>

.flex-col-center {
  display: flex;
  flex-direction: column;
  justify-content: center
}

</style>
相关推荐
独立开阀者_FwtCoder14 分钟前
面试官:为什么在 Vue3 中 ref 变量要用 .value?
前端·javascript·vue.js
NetX行者16 分钟前
基于Vue 3的AI前端框架汇总及工具对比表
前端·vue.js·人工智能·前端框架·开源
独立开阀者_FwtCoder17 分钟前
手握两大前端框架,Vercel 再出手拿下 Nuxt.js,对前端有什么影响?
前端·javascript·vue.js
独立开阀者_FwtCoder17 分钟前
弃用 html2canvas!快 93 倍的截图神器!
前端·javascript·vue.js
rui锐rui1 小时前
商品销售数据分析实验
vue.js·数据挖掘·数据分析
伍哥的传说1 小时前
H3初识——入门介绍之常用中间件
前端·javascript·react.js·中间件·前端框架·node.js·ecmascript
AA-代码批发V哥1 小时前
JavaScript之数组方法详解
javascript
洛小豆1 小时前
深入理解Pinia:Options API vs Composition API两种Store定义方式完全指南
前端·javascript·vue.js
Jokerator1 小时前
Vue 2现代模式打包:双包架构下的性能突围战
javascript·vue.js
洛小豆2 小时前
JavaScript 对象属性访问的那些坑:她问我为什么用 result.id 而不是 result['id']?我说我不知道...
前端·javascript·vue.js