
本文介绍了如何在JavaScript的异步邮件发送函数中添加成功提示。通过在fetch请求的.then()链中添加.finally()方法,确保无论请求成功还是失败,都能执行提示代码,从而改善用户体验。文章提供了修改后的代码示例,并解释了finally()方法的作用和优势。
在JavaScript中,当使用fetch API发送异步请求时,为了在邮件发送成功后向用户显示提示信息,可以使用.finally()方法。finally()方法会在Promise完成(resolve或reject)后始终执行,这使得它成为添加清理代码或显示最终状态(如“邮件已发送”或“发送失败”)的理想选择。
以下是如何修改原始代码以添加成功提示的步骤:
理解现有代码: 首先,确保你理解现有的invitePeopleToMyTeam()函数。它负责收集邮件地址,发送请求,并在成功后清除输入框。
立即学习“Java免费学习笔记(深入)”;
添加.finally(): 在fetch的.then()链中添加.finally()方法。这个方法接收一个函数作为参数,该函数将在Promise完成时执行。
下面是修改后的代码示例:
async function invitePeopleToMyTeam(){
let [invites,invite_statuses] = [[],$Q('.invitation-data.invite-access').slice(0,20)];
$Q('.invitation-data.invite-email').slice(0,20).map((i,ind)=>{
if(~i.value.search(/.+@.+\..+/gi)){
invites.push({
email:i.value.trim().toLowerCase(),
status:invite_statuses[ind].options[invite_statuses[ind].selectedIndex].innerHTML.slice(0,1).toLowerCase()
});
}else{
invite_statuses[ind] = null;
}
});
for(let i=0,il=invites.length; i<il; i++){
if(invites[i] === null){
invites.split(i,1);
il--;
i--;
continue;
}
if(invites[i].status == null || invites[i].status == ""){
invites[i].status = "m";
}
}
if(invites.length===0 || invites.filter(e=>e).length===0){
alert('There don\'t seem to be any e-mails in your invite list. Please review and try again.');
return false;
}
let sql = `./invitePeople.cfc?method=sendInvite`;
let params = {"invites" : invites};
let result = await fetch(sql, {
method:"post",
headers: {
'Accept': 'application/json',
'Content-Type': 'application/json'
},
body: JSON.stringify(params)
})
.then(resp => resp.text())
.then(resp=>{console.log(resp); return resp})
.then(r=>{
$Q('.invitation-data.invite-email').slice(0,20).map((i,ind)=>{
i.value= "";
})
})
.catch(e=>console.log(e))
.finally(() => {
alert('邮件已发送!');
});
}代码解释:
注意事项:
总结:
使用.finally()方法是在JavaScript异步函数中添加最终状态提示的有效方法。它确保无论请求成功还是失败,都能执行提示代码,从而提高用户体验。但是,请注意错误处理和用户体验,并根据需要选择更友好的提示方式。
以上就是JavaScript异步邮件发送成功后添加提示的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号