当前位置: 首页 > news >正文

JavaScript防御性编程

        简单聊一下防御性编程,初衷是开发人员为了防止自己被裁员,而将代码编写为只有自己能看懂。如何只有自己能看懂?方法多种多样,但不能将简单问题复杂化,比如:编写一堆无效的逻辑关系,或将业务复杂化。下面介绍一种方式,既能通过代码审查,又能提高代码水平。

        以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的开发人员,需要先理解该函数。但要说代码的可读性,这段代码也没问题,简单明了。

        简而言之,多使用高级函数,符号简写等等。

http://www.lryc.cn/news/276576.html

相关文章:

  • 微信预约小程序制作指南:从小白到专家
  • 向量数据库:Milvus
  • 亚马逊国际商品详情 API:获取特定商品详细信息的实践
  • MSB30M-ASEMI小贴片整流桥MSB30M
  • Redis启动方式
  • TEMU 新手小白必看!2024入驻流程/入驻类目/入驻资料等详细流程讲解
  • 【C语言】数组
  • 常见测试技术都有哪些?
  • Spring事务控制
  • swaggerUI不好用,试试这个openapiUI?
  • 嵌入式物联网项目开发实战例程-STM32F103系列之外围器件代码
  • Docker Compose--部署SpringBoot项目--实战
  • 单电阻FOC算法实现永磁同步电机的调整步骤和设置
  • 化学DS-1040 Tosylate 抑制剂 1335138-89-0科研用途
  • PaddlePaddle初使用
  • 【FPGA】分享一些FPGA数字信号处理相关的书籍
  • 深度解析JavaScript面试热点:事件循环、上下文、箭头函数、变量作用域与ES6模块
  • Javaweb之Mybatis的动态SQL的详细解析
  • 物联网与智能家居:跨境电商与未来生活的融合
  • Java内存模型(JMM)是基于多线程的吗
  • Linux离线安装MySQL(rpm)
  • 用 Socket.D 替代原生 WebSocket 做前端开发
  • Transformer架构和对照代码详解
  • 大数的乘法
  • 年度征文 | 机器学习之心的2023
  • 13.Kubernetes应用部署完整流程:从Dockerfile到Ingress发布完整流程
  • 多年后再用TB,谈项目管理工具
  • Spark MLlib ----- ALS算法
  • ubuntu桥接方式上网
  • 收到的字符串写入xml并且将这个xml写入.zip文件中