【前端开发必备小技巧】前端代码规范JavaScript篇

2024-08-30 02:36

本文主要是介绍【前端开发必备小技巧】前端代码规范JavaScript篇,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

  • 🟢 前端代码规范
  • 🟢 一、前端代码规范JavaScript篇
    • 👉1、JavaScript规范
        • 👉1.1、命名
        • 👉1.2、代码格式
        • 👉1.3、字符串
        • 👉1.4、对象声明
        • 👉1.5、使用 ES6,7
        • 👉1.6、 括号
        • 👉1.7、 undefined 判断
        • 👉1.8、 条件判断和循环最多三层
        • 👉1.9、 this 的转换命名
        • 👉1.10、慎用 console.log
  • ✒️总结


🟢 前端代码规范

规范的目的是为了编写高质量的代码,让你的团队成员每天得心情都是愉悦的,大家在一起是快乐的。
引自《阿里规约》的开头片段:
…现代软件架构的复杂性需要协同开发完成,如何高效地协同呢?无规矩不成方圆,无规范难以协同,比如,制订交通法规表面上是要限制行车权,实际上是保障公众的人身安全,试想如果没有限速,没有红绿灯,谁还敢上路行驶。对软件来说,适当的规范和标准绝不是消灭代码内容的创造性、优雅性,而是限制过度个性化,以一种普遍认可的统一方式一起做事,提升协作效率,降低沟通成本。代码的字里行间流淌的是软件系统的血液,质量的提升是尽可能少踩坑,杜绝踩重复的坑,切实提升系统稳定性,码出质量。

🟢 一、前端代码规范JavaScript篇

在这里插入图片描述

👉1、JavaScript规范

👉1.1、命名
  1. 采用小写驼峰命名 lowerCamelCase,代码中的命名均不能以下划线,也不能以下划线或美元符号结束
    反例:name /name/names
  2. 方法名、参数名、成员变量、局部变量都统一使用 lowerCamelcase风格,必须遵从驼峰形式。
    正例:1ocalvalue /getHttpMessage()/inputuserId
    其中 method 方法命名必须是 动词 或者 动词+名词 形式
    正例:saveshopcarData /openshopcarInfoDialog
    反例:save /open/show/go
    特此说明,增制查改,详情统一使用如下5个单词,不得使用其他(目的是为了统一各个端)
    add /update /delete /detail / get
  • 附: 函数方法常用的动词:
    • get 获取 / set 设置,
    • add 增加 / remove 删除
    • create 创建 / destory 移除
    • start 启动 / stop 停止
    • open 打开 / close 关闭
    • read 读瑕 / write 写入
    • load 载入 / save 保存
    • create 创建 / destroy 销毁
    • begin 开始 / end 结束
    • backup 备份 / restore 恢复
    • import 导入 / export 导出
    • split 分割 / merge 合并
    • inject 注入 / extract 提取
    • attach 附着 / detach 脱离
    • bind 绑定 / separate 分离
    • view 查看 / browse 浏览
    • edit 编辑 / modify 修改
    • select 选取 / mark 标记
    • copy 复制 / paste 粘贴
    • undo 撤销 / redo 重做
    • insert 插入 / delete 移除
    • add 加入 / append 添加
    • clean 清理 / clear 清除
    • index 索引 /sort 排序
    • find 查找 / search 搜索
    • increase 增加 / decrease 减少
    • play 播放 / pause 暂停
    • launch 启动 / run 运行
    • compile编译 / execute 执行
    • debug 调试 / trace 跟踪
    • observe 观察 / listen 监听
    • build 构建 / publish 发布
    • input 输入 / output 输出
    • encode 编码 / decode 解码
    • encrypt 加密 / decrypt 解密
    • compress 压缩 / decompress解压缩
    • pack 打包 /unpack 解包
    • parse 解析 / emit 生成
    • connect 连接 / disconnect 断开
    • send 发送 / receive 接收
    • download 下载 / upload 上传
    • refresh 刷新 / sychronize 同步
    • update 更新 / revert 复原
    • lock 锁定 / unlock 解锁
    • check out 签出 / check in 签入
    • submit 提交 / commit 交付
    • push 推 / pull 拉
    • expand 展开 / collapse 折叠
    • begin 起始 / end 结束
    • start 开始 / finish 完成
    • enter 进入 / exit 退出
    • abort 放弃 / quit 离开
    • obsolete 废弃 / depreciate 废旧
    • collect 收集 / aggregate 聚集
  1. 常量命名全部大写,单词间用下划线隔开,力求语义表达完整清楚,不要名字长。
    正例:MAX_STOCK_COUNT
    反例: MAX_COUNT
👉1.2、代码格式

使用2个空格进行缩进
正例:

if(x<y){x+=10;
}else{x+=1;
}

不同逻辑、不同语义、不同业务的代码之间插入一个空行分隔开来以提升可读性

说明:任何情形,没有必要插入多个空行进行隔开。

👉1.3、字符串

统一使用单引号('),不使用双引号(")。这在创建 HTML 字符串非常有好处:
正例:

let str='hello world'
let testDiv='<div id="test"></div'

反例

let str='hello world'
let testDiv="<div id='test'></div"
👉1.4、对象声明
  1. 使用字面值创建对象
    正例:let user ={};
    反例:let user =new object();
  2. 使用字面量来代替对象构造器

正例:

var user ={age:0,name:1,city:3
}

反例

var user =new object();
user.age =0;
user.name =0;
user.city =0;
👉1.5、使用 ES6,7

必须优先使用 ES6,7 中新增的语法糖和函数。这将简化你的程序,并让你的代码更加灵活和可复用。

必须强制使用 ES6,ES7 的新语法,比如箭头的数、await / async,解构,let, for…of等等

👉1.6、 括号

下列关键字后必须有大括号(即使代码块的内容只有一行):if,else,for,while,do,switch,try,catch,finally,with.

正例:

if(condition){d5something();
}

反例

if(condition){d5something();}
👉1.7、 undefined 判断

永远不要直接使用 undefined 进行变量判断;使用 sypeof和字符串’undefined’对变量进行判断。

正例:

if(typeof person === 'undefined'){
}

反例

if(person === undefined){
}
👉1.8、 条件判断和循环最多三层

条件判断能使用三目运算符和逻辑运算符解决的,就不要使用条件判断,但是谨记不要写太长的三目运算符。如果超过 3 层请抽成函数,并写清楚注释。

👉1.9、 this 的转换命名

对上下文 this 的引用只能使用’self来命名

👉1.10、慎用 console.log

因 çonsole.log大量使用会有性能问题,所以在非 webpack 项目中谨慎使用 log 功能

✒️总结

如果这篇【文章】有帮助到你💖,希望可以给我点个赞👍,创作不易,如果有对前端端或者对python感兴趣的朋友,请多多关注💖💖💖,咱们一起探讨和努力!!!
👨‍🔧 个人主页 : 前端初见

这篇关于【前端开发必备小技巧】前端代码规范JavaScript篇的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1119561

相关文章

Java中ArrayList和LinkedList有什么区别举例详解

《Java中ArrayList和LinkedList有什么区别举例详解》:本文主要介绍Java中ArrayList和LinkedList区别的相关资料,包括数据结构特性、核心操作性能、内存与GC影... 目录一、底层数据结构二、核心操作性能对比三、内存与 GC 影响四、扩容机制五、线程安全与并发方案六、工程

部署Vue项目到服务器后404错误的原因及解决方案

《部署Vue项目到服务器后404错误的原因及解决方案》文章介绍了Vue项目部署步骤以及404错误的解决方案,部署步骤包括构建项目、上传文件、配置Web服务器、重启Nginx和访问域名,404错误通常是... 目录一、vue项目部署步骤二、404错误原因及解决方案错误场景原因分析解决方案一、Vue项目部署步骤

JavaScript中的reduce方法执行过程、使用场景及进阶用法

《JavaScript中的reduce方法执行过程、使用场景及进阶用法》:本文主要介绍JavaScript中的reduce方法执行过程、使用场景及进阶用法的相关资料,reduce是JavaScri... 目录1. 什么是reduce2. reduce语法2.1 语法2.2 参数说明3. reduce执行过程

如何使用Java实现请求deepseek

《如何使用Java实现请求deepseek》这篇文章主要为大家详细介绍了如何使用Java实现请求deepseek功能,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1.deepseek的api创建2.Java实现请求deepseek2.1 pom文件2.2 json转化文件2.2

Java调用DeepSeek API的最佳实践及详细代码示例

《Java调用DeepSeekAPI的最佳实践及详细代码示例》:本文主要介绍如何使用Java调用DeepSeekAPI,包括获取API密钥、添加HTTP客户端依赖、创建HTTP请求、处理响应、... 目录1. 获取API密钥2. 添加HTTP客户端依赖3. 创建HTTP请求4. 处理响应5. 错误处理6.

Spring AI集成DeepSeek的详细步骤

《SpringAI集成DeepSeek的详细步骤》DeepSeek作为一款卓越的国产AI模型,越来越多的公司考虑在自己的应用中集成,对于Java应用来说,我们可以借助SpringAI集成DeepSe... 目录DeepSeek 介绍Spring AI 是什么?1、环境准备2、构建项目2.1、pom依赖2.2

Spring Cloud LoadBalancer 负载均衡详解

《SpringCloudLoadBalancer负载均衡详解》本文介绍了如何在SpringCloud中使用SpringCloudLoadBalancer实现客户端负载均衡,并详细讲解了轮询策略和... 目录1. 在 idea 上运行多个服务2. 问题引入3. 负载均衡4. Spring Cloud Load

Springboot中分析SQL性能的两种方式详解

《Springboot中分析SQL性能的两种方式详解》文章介绍了SQL性能分析的两种方式:MyBatis-Plus性能分析插件和p6spy框架,MyBatis-Plus插件配置简单,适用于开发和测试环... 目录SQL性能分析的两种方式:功能介绍实现方式:实现步骤:SQL性能分析的两种方式:功能介绍记录

在 Spring Boot 中使用 @Autowired和 @Bean注解的示例详解

《在SpringBoot中使用@Autowired和@Bean注解的示例详解》本文通过一个示例演示了如何在SpringBoot中使用@Autowired和@Bean注解进行依赖注入和Bean... 目录在 Spring Boot 中使用 @Autowired 和 @Bean 注解示例背景1. 定义 Stud

使用 sql-research-assistant进行 SQL 数据库研究的实战指南(代码实现演示)

《使用sql-research-assistant进行SQL数据库研究的实战指南(代码实现演示)》本文介绍了sql-research-assistant工具,该工具基于LangChain框架,集... 目录技术背景介绍核心原理解析代码实现演示安装和配置项目集成LangSmith 配置(可选)启动服务应用场景