表单提交是

复制代码
<template>  
    <el-form :model="form" :rules="rules" ref="form" label-width="120px">  
      <el-form-item label="姓名" prop="name">  
        <el-input v-model="form.name"></el-input>  
      </el-form-item>  
      <el-form-item label="年龄" prop="age">  
        <el-input v-model="form.age"></el-input>  
      </el-form-item>  
      <el-form-item label="住址" prop="address">  
        <el-input v-model="form.address"></el-input>  
      </el-form-item>  
      <el-form-item label="电话" prop="phone">  
        <el-input v-model="form.phone"></el-input>  
      </el-form-item>  
      <el-form-item>  
        <el-button type="primary" @click="submitForm('form')">提交</el-button>  
      </el-form-item>  
    </el-form>  
  </template>

<script>  
export default {  
  data() {  
    return {  
      form: {  
        name: '',  
        age: '',  
        address: '',  
        phone: ''  
      },  
      rules: {  
        name: [  
          { required: true, message: '请输入姓名', trigger: 'blur' },  
          { min: 3, max: 15, message: '长度在 3 到 15 个字符', trigger: 'blur' }  
        ],  
        age: [  
          { required: true, message: '请输入年龄', trigger: 'blur' },  
          { min: 18, max: 100, message: '年龄在 18 到 100 岁之间', trigger: 'blur' }  
        ],  
        address: [  
          { required: true, message: '请输入住址', trigger: 'blur' },  
          { min: 5, max: 20, message: '长度在 5 到 20 个字符', trigger: 'blur' }  
        ],  
        phone: [  
          { required: true, message: '请输入电话号码', trigger: 'blur' },  
          { pattern: /^1[3456789]\d{9}$/, message: '请输入正确的电话号码', trigger: 'blur' }  
        ]  
      },  
      apiUrl: 'https://example.com/api/submit' // 后端接口的URL  
    };  
  },  
  methods: {  
    submitForm(formName) {  
      this.$refs[formName].validate((valid) => {  
        if (valid) {  
          // 表单验证通过,提交表单数据到后端接口  
          axios.post(this.apiUrl, this.form)  
            .then((response) => {  
              // 后端接口返回成功处理逻辑...  
              console.log('提交成功');  
            })  
            .catch((error) => {  
              // 后端接口返回失败处理逻辑...  
              console.log('提交失败');  
            });  
        } else {  
          // 表单验证失败,显示错误信息...  
          console.log('表单验证失败');  
          return false;  
        }  
      });
    }
}
}
    </script>  
相关推荐
xiaoqi92241 分钟前
React Native鸿蒙跨平台如何进行狗狗领养中心,实现基于唯一标识的事件透传方式是移动端列表开发的通用规范
javascript·react native·react.js·ecmascript·harmonyos
jin1233221 小时前
React Native鸿蒙跨平台剧本杀组队消息与快捷入口组件,包含消息列表展示、快捷入口管理、快捷操作触发和消息详情预览四大核心功能
javascript·react native·react.js·ecmascript·harmonyos
烬头88213 小时前
React Native鸿蒙跨平台实现二维码联系人APP(QRCodeContactApp)
javascript·react native·react.js·ecmascript·harmonyos
pas1363 小时前
40-mini-vue 实现三种联合类型
前端·javascript·vue.js
2601_949833393 小时前
flutter_for_openharmony口腔护理app实战+预约管理实现
android·javascript·flutter
军军君014 小时前
Three.js基础功能学习十三:太阳系实例上
前端·javascript·vue.js·学习·3d·前端框架·three
xiaoqi9225 小时前
React Native鸿蒙跨平台如何实现分类页面组件通过searchQuery状态变量管理搜索输入,实现了分类的实时过滤功能
javascript·react native·react.js·ecmascript·harmonyos
qq_177767375 小时前
React Native鸿蒙跨平台实现应用介绍页,实现了应用信息卡片展示、特色功能网格布局、权限/联系信息陈列、评分展示、模态框详情交互等通用场景
javascript·react native·react.js·ecmascript·交互·harmonyos
2603_949462105 小时前
Flutter for OpenHarmony社团管理App实战:预算管理实现
android·javascript·flutter
wuhen_n6 小时前
JavaScript内存管理与执行上下文
前端·javascript