Vue3 + elementplus实现表单验证+上传图片+ 防止表单重复提交功能

首先,上官网地址

https://element.eleme.cn/

首先页面上面用了弹窗的形式,做完之后长这样,有全屏,关闭等按钮,上效果图和完整代码!!!!!

<!--点击新增按钮 -->
<div class="addbtn" @click="fundOperation()">
  <span>+</span> 新增
</div>

<el-dialog
        v-model="datadialog"
        :show-close="true"
        :close-on-click-modal="false"
        width="746px"
        :title="dialogtitle"
        :fullscreen="fullscreen"
        :destroy-on-close="true"
        @close="closeDialog"
      > <!--是否全屏-->
      <div class="fullicon" @click="fullscreen = !fullscreen"> <img src="../../assets/info_open.png" alt=""></div>
      <div class="box-title"> <img src="../../assets/info_basic.png" alt="">  <span>基本信息</span> </div>
        <el-form
          :model="ruleForm"
          :rules="rules"
          label-width="120px"
          label-position="right"
          class="demo-ruleForm"
          :size="formSize"
          ref="ruleFormRef"
        >

          <el-form-item label="标题" prop="title">
            <el-input v-model="ruleForm.title" placeholder="请输入80个字符以内标题" :clearable="true" label-width="100%"  maxlength="80"  autocomplete="off" />
          </el-form-item>
          <el-form-item
            prop="img"
            class="upload"
            label="上传图片"
            v-loading="loading"
          >
            <el-upload
              class="upload-demo"
              :limit="1"
              action="/api/v1/upload/file"
              name="multipartFile"
              :on-success="uploadSucceed"
              :on-error = "uploadError"
              :file-list="fileList"
              list-type="picture"
              :before-upload="beforeUpload"
              :on-remove="fileRemoved"
              accept=".jpg,.jpeg,.png,.JPG,.JPEG"
              ref="upload"
            >
              <el-button size="small" type="primary">点击上传</el-button>
            </el-upload>
            <div class="el-upload__tip">图片尺寸:600*200,图片5MB以内,图片格式支持JPG、JPEG、PNG</div>
          </el-form-item>
          <!-- 是否推荐    0不推荐  1推荐-->
          <el-form-item
            prop="recommend"
            label="是否推荐"
          >
            <el-select
              v-model="ruleForm.recommend"
              placeholder="请选择是否推荐"
            >
              <el-option  label="是" :value="1" ></el-option>
              <el-option  label="否"  :value="0"  ></el-option>
            </el-select>
          </el-form-item>
          <el-form-item label="特殊资源" prop="share">
            <el-radio-group v-model="ruleForm.share">
              <el-radio label="线上品牌商赞助"></el-radio>
              <el-radio label="线下场地免费"></el-radio>
            </el-radio-group>
          </el-form-item>
          <el-form-item label="活动性质" prop="type">
            <el-checkbox-group v-model="ruleForm.type">
              <el-checkbox label="美食/餐厅线上活动" name="type"></el-checkbox>
              <el-checkbox label="地推活动" name="type"></el-checkbox>
              <el-checkbox label="线下主题活动" name="type"></el-checkbox>
              <el-checkbox label="单纯品牌曝光" name="type"></el-checkbox>
            </el-checkbox-group>
          </el-form-item>
          <el-form-item label="活动形式" prop="content">
            <el-input type="textarea" v-model="ruleForm.content"></el-input>
          </el-form-item>
        </el-form>

        <template #footer>
          <span class="dialog-footerData" >
            <!-- 当使用指令方式时,全屏遮罩需要添加fullscreen修饰符(遮罩会插入至 body 上),此时若需要锁定屏幕的滚动,可以使用lock修饰符;当使用服务方式时,遮罩默认即为全屏,无需额外设置。-->

         <el-button  class="bai" @click="dataCancel" >取消</el-button>
              <el-button type="primary" @click="dataConfirm(1)" v-loading.fullscreen.lock="fromloading">发布</el-button>

          </span>
        </template>
      </el-dialog>

表单校验 和数据提交

<script>
import { useRoute } from 'vue-router'
import { toRefs, reactive, ref, unref} from 'vue'
import axios from '../../api/news' // axios 接口求情
import router from '../../router';
import {ElMessage} from 'element-plus';
 
export default {
  setup() {
    const route = useRoute();
    const datadialog = ref(false) // 新增弹窗
    const upload = ref("");   //上传
    const ruleFormRef = ref(null); //表单
    let formSize = 'default';
    let ruleForm = reactive({
      title:'',// 标题
      img:'',//图片
      recommend: '',//是否推荐  
      share: '',// 特殊资源
      type: '',// 活动性质
      content:'' ,// 内容
    });
    //表单校验
    const rules = reactive({
      title: {required: true, message: '请输入标题', trigger: 'blur'},
      img: {required: true, message: '请上传图片', trigger: 'blur'},
      content: {required: true, message: '请填写活动形式', trigger: 'blur'},  
      recommend: {required: true, message: '请选择特殊资源 ', trigger: 'change'},
      share: {required: true, message: '请选择是否允许分享', trigger: 'change'},
      type: [{ type: 'array', required: true, message: '请至少选择一个活动性质', trigger: 'change' }],
    })
    const data = reactive({  
      infoData:[],
      fileList:[],
      loading: false,
      dialogtitle:'',//弹窗标题
      fullscreen:false,
      fromloading:false,
    }) 
    //  新增弹窗 
    function fundOperation(){
      data.fullscreen = false
      ruleForm.img = ""; // 清空文件图片地址
      data.fileList = [];
      // 清空表单数据
      Object.keys(ruleForm).map(key => {
        delete ruleForm[key]
      })
      data.dialogtitle = '新增'
      datadialog.value = true;  //  显示弹窗
    }
    // 上传图片方法
    function beforeUpload(file, fileList) {
       data.loading = true;
        const isLt10M = file.size / 1024 / 1024 < 5;
        if (!isLt10M) {
          ElMessage('上传头像图片大小不能超过 5MB!');
          data.loading = false;
        }
       return isLt10M;
     
    }  
    // 图片被移除
    function fileRemoved(file, fileList) {
      if (file && file.status === "success") {
        //移除前方法
        ruleForm.img = ""; // 清空文件图片地址
      }
    }
    // 文件上传成功
    function uploadSucceed(res) {
      if (res.code == 200) {
        data.loading = false;
        ruleForm.img = res.data.url; // 图片链接
      }else{
        ruleForm.img = ''; // 图片链接
      }
     
    }
    function uploadError(){
      data.loading = false;
      ElMessage.error("图片上传失败");
      ruleForm.img = ''; // 图片链接
    }
    // 编辑数据 取消
    function dataCancel(){
      data.fileList = [];  
      Object.keys(ruleForm).map(key => {
        delete ruleForm[key]
      })
      data.loading = false;
      datadialog.value = false;
      data.fullscreen = false;
    }
    async function dataConfirm(){  
      data.fromloading = true; //
      const form = unref(ruleFormRef);
      if (!form) return;
      try {
           await ruleFormRef.value.validate((valid) => {
            // 验证通过 请求接口
              if (valid) {
          //写自己的接口地址哦
                 axios.addApi(ruleForm).then(res => {
                    if (res.code == 200) {
                      data.fileList = []; 
                      data.loading = false;
                      datadialog.value = false;
                      data.fullscreen = false;
                      data.fromloading = false; 
                      // ElMessage.success('操作成功');  //默认时间 方式
                      ElMessage.success({
                        message:'操作成功',
                        duration:2500
                      });
                    }else{
                      data.fromloading = false;
                      ElMessage.error(res.message);
                    }
                  })
                 
              } else {
                // 验证失败 取消loading,
                data.fromloading = false;
                return;
              }
            })  
           
        } catch (error){
           // 验证失败 取消loading,
          data.fromloading = false;
        }  
    }
     
    return {
      ...toRefs(data), 
      fundOperation,
      datadialog,
      dataCancel,
      dataConfirm,
      ruleForm,
      formSize,
      rules,  
      fileRemoved,
      uploadSucceed,
      uploadError,
      upload,
      beforeUpload,  
      ruleFormRef
    }
  },
}
</script>

到此这篇关于Vue3 + elementplus 表单验证+上传图片+ 防止表单重复提交的文章就介绍到这了,更多相关Vue3  elementplus表单验证内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • element-ui如何防止重复提交的方法步骤

    先说对话框(Dialog)里的表单提交 错误方案 说起错误方案,比如,点击提交按钮,本地验证,验证通过立即让按钮不可点,这些没问题,而我的错误点概括是:在某个最后执行的回调函数的最后一行,我做了2个操作:1,隐藏Dialog,2,让提交按钮可点击. 这个方案看似没问题,做到了让对话框消失,又保证下一次打开Dialog之后,提交按钮是可点击的.但它错误在于:隐藏Dialog是一个动画过程,并不是瞬间消失,所以按钮恢复可点击之后,Dialog还没有彻底隐藏,所以只要你点得够快,就可以多点几次按钮.

  • jQuery Validate表单验证插件的基本使用方法及功能拓展

    1 表单验证的准备工作 在开启长篇大论之前,首先将表单验证的效果展示给大家. 1.点击表单项,显示帮助提示            2.鼠标离开表单项时,开始校验元素             3.鼠标离开后的正确.错误提示及鼠标移入时的帮助提醒 对于初学者而言,html表单验证是一项极其琐碎的事情.要做好表单验证,需要准备以下基本要素: 1.html表单结构:包含需要校验的表单元素: 2.js逻辑控制:在需要校验的表单元素上绑定事件,如点击.获取焦点.失去焦点等事件,并设置这些事件对应的执行函数:

  • Bootstrap 表单验证formValidation 实现表单动态验证功能

    动态添加input并动态添加新验证方式! init状态: 点击"+"后: 验证后: 知识点: 1 先去官网下载:http://formvalidation.io/ 2 导入文件,注意事项我就不多说了在远程验证那篇我已经讲过. 3 用到的关键字:addField.removeField.different 4注意一点就是官网里的例子他们的name是不一样的.我这里比较偷懒.且项目ajax的时候不是用的form表单提交,而是自己并接成json提交,所以x,y的name的名字一样. 好开始:

  • PHP实现防止表单重复提交功能【基于token验证】

    本文实例讲述了PHP实现防止表单重复提交功能.分享给大家供大家参考,具体如下: 防止表单重复提交的方法有很多种,那么今天就给大家介绍一种php如何有效的防止表单重复提交. 代码非常简单 我相信大家很聪明给大家分享一个小的demo,大家可以借鉴一下: 具体代码: <?php /* * 2016年9月29日08:09:13 */ session_start(); header("Content-Type: text/html;charset=utf-8"); function set

  • 微信小程序表单验证插件WxValidate的二次封装功能(终极版)

    微信小程序表单验证前面的两篇文章做的效果总感觉都有点不太友好,第一篇里的效果是将错误信息通过对话框形式弹出来,这种形式在web形式下早已经淘汰了:第二篇是一次性全部显示所有的错误,然后3秒后自动消失, 这种在极端情况下也不太好,例如我例子里的一页的表单个数非常多的情况下,可能后面的还没看到就消失了.所以最近又重新做了一版,最终版的效果如下图:错误信息一次性全部显示,可以通过点击信息框让其消失,将自动消失时间设置的稍微长点,例如10秒,这样就能比较好的兼顾效果和使用上的便捷. 先讲讲最终版与前面2

  • 仅一个form表单 js实现注册信息依次填写提交功能

    我们原先是一个很长的form表单,里面有很多选项.客户反馈这样不够友好,容易看花眼.因此进行改进,实现多步骤进度,多个提交的实现(其实只有一个form提交). 实现的思路:将表单的选项装入多个div中,一个显示,其他隐藏. 实现效果如下: 1.JavaScript代码 <script type="text/javascript" src="js/jquery.js"></script> <script type="text/j

  • VUE中使用TypeScript装饰器实现表单验证的全过程

    目录 前言 装饰器 class-validator 封装Validator 具体使用 小结 前言 最近接触了关于很多TypeScript装饰器的知识,以及class-validator这个用装饰器来做表单验证的包,就萌生了想在vue中使用装饰器来做表单验证的想法.class-validator允许我们在类上通过使用装饰器来完成表单的验证,并且可在浏览器端和node端同时使用.那么接下来先简单介绍一下装饰器和class-validator的用法. 装饰器 装饰器的语法十分简单,只需要在想使用的装饰

  • 一个即时表单验证的javascript代码

    可爱吧--教你做可爱女人--化妆 美容 美化 瘦身 护肤--深圳可爱吧 // 此脚本由刘海民编写 // 网站:http://www.szrgb.net // 邮箱:lovelium@gmail.com var num=5; var mon1=0; var mon2=0; var mon3=0; var mon4=0; var mon5=0; //封装得到对像ID涵数 function getObj(objName){return(document.getElementById(objName))

  • Ajax注册用户时实现表单验证

    很多时候在网站上注册时,我们会发现,注册表单通常需要检查用户名和电子邮件地址的可用性:从而确保用户之间不拥有相同的用户名和电子邮件地址:一些网站喜欢在用户提交填写的用户信息时,做信息可用性的检查,而一些网站会做实时的用户名和电子邮件地址可用性检查,例如:"用户名"文本框失去焦点时:就用户体验来说,实时的用户信息检查用户体验效果更好,而不是在表单提交后,告诉用户信息不符合系统要求. 下面截图是新浪微博的注册界面,它采用的是实时的用户信息检查,如:手机号码和用户名等信息. 图1新浪微博注册

  • jQuery表单验证插件formValidator(改进版)

    枚举对象的使用: 复制代码 代码如下: //各种验证方式支持的标签类型 sustainType: function (elem, setting) { var srcTag = elem.tagName; var stype = elem.type; switch (setting.validatetype) { case _validTypeEnum.InitValidator: return true; case _validTypeEnum.InputValidator: if (srcT

  • JavaScript表单验证开发

    本文实例为大家分享了js表单验证的具体代码,供大家参考,具体内容如下 在线demo:http://www.hui12.com/nbin/csdn/jsInput/demo.html 效果图: /* 验证类型 testName: "验证用户", testPassword: "密码", testPhone: "手机号码", testQQ: "验证QQ", testLength: "验证是否在指定长度内", //

随机推荐