JavaScript防御性编程
2024-01-08 12:43:57
? ? ? ? 简单聊一下防御性编程,初衷是开发人员为了防止自己被裁员,而将代码编写为只有自己能看懂。如何只有自己能看懂?方法多种多样,但不能将简单问题复杂化,比如:编写一堆无效的逻辑关系,或将业务复杂化。下面介绍一种方式,既能通过代码审查,又能提高代码水平。
? ? ? ? 以vue为例,以下是计算所有产品价格:
computed: {
extraPrice() {
try {
return (
let cPrices = 0;
this.cProducts.forEach((item) => {
cPrices = cPrices + item.num * item.price;
//或 cPrices += item.num * item.price;
});
this.aProduct.num * this.aProduct.price +
this.bProduct.num * this.bProduct.price +
cPrices
);
} catch (e) {
console.log('价格计算有误');
return 0;
}
}
}
上面代码简单明了,大部分开发人员都能读懂,那么有没有高级一点的写法,当然有:
computed: {
extraPrice() {
try {
return (
this.aProduct.num * this.aProduct.price +
this.bProduct.num * this.bProduct.price +
this.cProduct.reduce((total,item) => total + item.num * item.price,0)
);
} catch (e) {
console.log('价格计算有误');
return 0;
}
}
}
对于不经常使用reduce的开发人员,需要先理解该函数。但要说代码的可读性,这段代码也没问题,简单明了。
? ? ? ? 简而言之,多使用高级函数,符号简写等等。
文章来源:https://blog.csdn.net/hhbbeijing/article/details/135452396
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!