前端开发:Vue封装一个公用的的Submit方法

简介: 最近新学Vue,后台开发中经常用到提交,索性把提交功能给做成全局方法,下面为封装的代码。//封装默认提交方法Vue.prototype.mySubmit = function (options) { var that = this; //避免this指向被改变 var url = options.

最近新学Vue,后台开发中经常用到提交,索性把提交功能给做成全局方法,下面为封装的代码。

//封装默认提交方法

Vue.prototype.mySubmit = function (options) {
 var that = this; //避免this指向被改变
 var url = options.url || location.href;
 var post = options.post || "post";
 var data = options.data || {}; //要提交的数据
 var callBack = options.callBack;
 var successMsg = options.successMsg || "恭喜你,提交成功!";
 var confirmMsg = options.confirmMsg; //确定文字,如果有会先弹出是否确定按钮
 varformName = options.formName;
 this.$refs["formName"].validate(function (valid) {
 if (valid) {
 if (confirmMsg) {
 that.$confirm(confirmMsg, '提示', {
 confirmButtonText: '确定',
 cancelButtonText: '取消',
 }).then(() => {
 submit(that);
 }).catch(() => {
 });
 }
 else {
 submit(that);
 }
 } else {
 return false;
 }
 });
 function submit(vue) {
 var loading = ELEMENT.Loading.service({ fullscreen: true });
 var ajaxOptions = {
 url: url,
 type: "post",
 data: data,
 success: function (data) {
 ELEMENT.Message.success({
 message: successMsg,
 });
 loading.close();
 if (typeof callBack == "function") {
 callBack();
 }
 },
 fail: function (data) {
 alert(data);
 loading.close();
 }
 }
 Ajax(ajaxOptions);
 }
}

使用方法如下:

html部分:

<button type="button" v-on:click="submit" class="btn btn-primary">提交</button>

js部分

var vue= new Vue({
 el: "#el",
 data: {
 formData: {},
 },
 methods: {
 submit: function () {
 this.paSubmit({url:"/post/",data:this.formData});
 },
 },
 });
相关文章
|
5天前
|
Web App开发 缓存 JavaScript
优化Vue首页加载速度的实用方法
优化Vue首页加载速度的实用方法
14 1
|
22小时前
|
JSON JavaScript 前端开发
vue的 blob文件下载文件时,后端自定义异常,并返回json错误提示信息,前端捕获信息并展示给用户
vue的 blob文件下载文件时,后端自定义异常,并返回json错误提示信息,前端捕获信息并展示给用户
|
1天前
|
JavaScript
vue里样式不起作用的方法,可以通过deep穿透的方式
vue里样式不起作用的方法,可以通过deep穿透的方式
|
1天前
|
前端开发 BI
jeecgboot中前端使用带有参数报表的方法
jeecgboot中前端使用带有参数报表的方法
|
2天前
|
前端开发 JavaScript 开发者
实用技巧:提高前端开发效率的5个方法
提高前端开发效率是每个开发者都追求的目标。本文将介绍5个实用的技巧,帮助前端开发者提升工作效率:使用代码片段加速开发、合理利用浏览器开发者工具、充分利用现有框架和库、使用自动化构建工具、保持学习和不断优化工作流程。
|
2天前
|
JavaScript 前端开发
vue前端展示【1】
vue前端展示【1】
7 1
|
2天前
|
JavaScript
vue实现多个el-form表单提交统一校验的2个方法
vue实现多个el-form表单提交统一校验的2个方法
6 0
|
3天前
|
缓存 JavaScript 开发者
什么是vue的计算属性?为什么使用?计算属性和方法有什么区别?怎样选择
什么是vue的计算属性?为什么使用?计算属性和方法有什么区别?怎样选择
9 0
|
4天前
|
JavaScript
Vue自定义指令的三个方法
Vue自定义指令的三个方法
7 0
|
9天前
|
JavaScript
Vue.js 中父组件调用子组件的方法
Vue.js 中父组件调用子组件的方法
36 2