首页 > 其他分享 >dojo利用promise实现多个异步校验

dojo利用promise实现多个异步校验

时间:2022-11-26 21:46:05浏览次数:50  
标签:异步 dojo console log results promise var docSubject

代码如下:

// 敏感词过滤
var promiseAll = checkSenstiveWords();
promiseAll.then(function (results) {
	// console.log("results=>", results)
	// console.log("v1=>", results[0].flag);
	// console.log("v2=>", results[1].flag);
	// console.log("v3=>", results[2].flag);

	if(results[0].flag == true){
		Tip.fail({
			"text": msg["errors.sensitive.word.warn"]
				.replace("{0}", lang["kmsMultidoc.kmsMultidocKnowledge.docSubject"])
				.replace("{1}", '<span style="color:#cc0000">' + results[0].senWords + '</span>')
		});
		return ;
	}
	if (results[1].flag == true) {
		Tip.fail({
			"text": msg["errors.sensitive.word.warn"]
				.replace("{0}", lang["kmsMultidocKnowledge.fdDescription"])
				.replace("{1}", '<span style="color:#cc0000">' + results[1].senWords + '</span>')
		});
		return;
	}
	if (results[2].flag == true) {
		Tip.fail({
			"text": msg["errors.sensitive.word.warn"]
				.replace("{0}", lang["kmsMultidoc.kmsMultidocKnowledge.docContent"])
				.replace("{1}", '<span style="color:#cc0000">' + results[2].senWords + '</span>')
		});
		return;
	}
	
	// 校验成功
	// do something
}, function () {
	Tip.fail({"text" : lang['mui.return.failure']});
})

具体的校验方法

window.checkSenstiveWords = function () {
	var docSubject = document.getElementsByName("docSubject")[0].value;
	var fdDescription = document.getElementsByName("fdDescription")[0].value;
	var docContent = document.getElementsByName("docContent")[0].value;
	console.log("docSubject=>", docSubject);
	console.log("fdDescription=>", fdDescription);
	console.log("docContent=>", docContent);

	var suburl = util.formatUrl(self.senstiveValidateUrl);
	var subdata = {"content": encodeURIComponent(docSubject), formName: "kmsMultidocKnowledgeForm"};
	var docSubjectPromise = request.post(suburl, {data: subdata, method: 'POST', handleAs: 'json'});

	var desurl = util.formatUrl(self.senstiveValidateUrl);
	var desdata = {"content": encodeURIComponent(fdDescription), formName: "kmsMultidocKnowledgeForm"};
	var fdDescriptionPromise = request.post(desurl, {data: desdata, method: 'POST', handleAs: 'json'});

	var conurl = util.formatUrl(self.senstiveValidateUrl);
	var condata = {"content": encodeURIComponent(docContent), formName: "kmsMultidocKnowledgeForm"};
	var docContentPromise = request.post(conurl, {data: condata, method: 'POST', handleAs: 'json'});

	return all([docSubjectPromise, fdDescriptionPromise, docContentPromise])
}

import

define([
	"dojo/_base/declare",
	 "mui/dialog/Tip",
	 "mui/form/validate/Validation",
	 "mui/i18n/i18n!:errors.sensitive.word.warn",
	 "mui/i18n/i18n!kms-multidoc:kmsMultidoc",
	 "dojo/topic", 
	 "dijit/registry",
	 "dojo/query",
	 "dojo/request",
	 "dojo/promise/all",
	 "mui/util",
	], function(declare,Tip, Validation, msg, lang,topic,registry,query,request,all,util) {

	return declare("kms.multidoc.edit", null,{
		validateUrl:'/kms/multidoc/kms_multidoc_knowledge/kmsMultidocKnowledge.do?method=checkAddSubject&fdId=!{fdId}&docSubject=!{docSubject}&cateId=!{cateId}',

		senstiveValidateUrl:'/sys/profile/sysCommonSensitiveConfig.do?method=getIsHasSensitiveword'
	
		// ...
		// 其他代码
	});
});

标签:异步,dojo,console,log,results,promise,var,docSubject
From: https://www.cnblogs.com/tangyouwei/p/dojo-uses-promise-to-implement-multiple-asynchronous-

相关文章

  • 手把手教你使用ts 一步一步的去完成一个Promise
    前奏笔者公司前端小组,线上出现了因为Promise用错了而导致的问题。本文的出发点不仅是了解Promise,主要目的是跟着特性去写一个Promise。所以前提是你已经掌握了Promise的......
  • Promise的使用
    一、Promise的简单使用Promise可以用来封装异步操作,表示将来会发生某个操作,可以直接通过new对象来使用letp1=newPromise(function(resolve,reject){set......
  • Javascript(笔记52) - promise - 2 API和方法
    Promise 构造函数Promise(excutor){}1)executor 函数:执行器(resolve,reject)=>{}2)resolve 函数:内部定义成功时我们调用的函数value=>{}3)reject函数:内定定义失败时我们......
  • 腾讯会议开始收费?录屏异步沟通解决开会难题
    腾讯会议宣布部分功能开始收费,有涉及个人用户。一石激起千层浪近,不少用户在社交平台上吐槽腾讯会议突然收费带来的不良体验。腾讯会议客服介绍称,包括实录转换文字、设置联......
  • 四种PHP异步执行的常用方式
    客户端与服务器端是通过HTTP协议进行连接通讯,客户端发起请求,服务器端接收到请求后执行处理,并返回处理结果。有时服务器需要执行很耗时的操作,这个操作的结果并不需要返回给客......
  • Uncaught(in promise) TypeError: data.map is not a function 控制台报错
     这个报错意思提示data.map不是一个函数,表明map这个方法不存在没起到作用,map函数只对数组起作用,表明data不是一个数组对map函数起不到作用,所以需添加以下代码做一个判......
  • 聊聊异步编程CompletionService的使用
    在日常需求的研发过程中都遇到过需要调用多个服务并将他们的结果进行合并的需求。这种情形又分为多个结果相互不依赖的情况,以及多个调用的结果相互依赖。比如一个首页,需要......
  • CompletableFuture异步任务编排
    业务场景:查询详情页的逻辑比较多,有些数据还需要远程调用,必然要花费更多的时间。1、获取SKU的基本信息0.5s2、获取SKU的图片信息0.5s3、获取SKU的促销信息1s4、获取SPU的......
  • 搞清楚Promise.all的异常处理
    参考资料:https://www.jianshu.com/p/356f10ee476dhttps://blog.csdn.net/aaqingying/article/details/122966849https://www.cnblogs.com/hill-foryou/p/12512885.html......
  • vue+element-ui异步加载树结构-前端(全)
    element-ui异步加载行政区划树功能:进入页面,左侧显示行政区划树的顶级目录,单击目录左侧的箭头,则向后端发送请求,获得该级目录的子目录;以此类推;点击目录本身,则向后端发请求和右......