使用some 或者 every 方法遇到异常没有return
2024-01-01 06:20:32
使用some 或者 every 方法遇到异常没有return
解决方法
使用for循环或者for of遍历
for (const file of filesArray) {
try {
formatBytes(file.size);
} catch (e: any) {
setErrorMessage(e.message);
return;
}
}
问题复现
写了一个方法(formatBytes
)将文件的大小自动转换成MB
,KB
等,如果其中文件大小超过指定大小会抛出异常。想法是在遍历文件列表时如果超过指定大小,给出提示并且直接return
。
formatBytes
方法
import { maxFileSize } from '@/config/fileType';
export function formatBytes(bytes: number, decimals = 2) {
const size = maxFileSize * 1024 * 1024;
if (bytes > size) {
throw new Error(`文件不能超过${maxFileSize}M`);
}
if (bytes === 0) return '0 Bytes';
const k = 1024;
const dm = decimals < 0 ? 0 : decimals;
const sizes = ['Bytes', 'KB', 'MB', 'GB', 'TB', 'PB', 'EB', 'ZB', 'YB'];
const i = Math.floor(Math.log(bytes) / Math.log(k));
return `${parseFloat((bytes / Math.pow(k, i)).toFixed(dm))} ${sizes[i]}`;
}
然而,在实际使用中,无论是使用some
、forEach
还是every
方法,都会在最后设上值。在遇到异常时,这几个方法并没有立即返回。
代码如下
// 文件改变时
const handelFilesChange = (event: any) => {
const filesArray: File[] = Array.from(event.target.files);
filesArray.forEach(file => {
try {
formatBytes(file.size);
} catch (e: any) {
setErrorMessage(e.message);
return;
}
});
const map = filesArray.map(file => ({ id: uuid(), file }));
setFiles(map);
};
通过使用普通的
for
循环或for...of
遍历,可以在捕获到异常时直接设置错误消息并立即返回,避免在异常情况下继续执行不必要的代码。
文章来源:https://blog.csdn.net/weixin_46533577/article/details/135321633
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!