如何写好你的JavaScript【推荐】
发布时间 - 2026-01-10 23:23:11 点击率:次前言

在实际工作中,我们应该经常会看到一些功能上没有问题,但编码风格和规范却十分糟糕的代码,这往往会让人不敢再往下阅读,甚至会影响阅读者一天的心情。这些代码不仅不易阅读,而且难以维护,它们一般会出自刚入门的编程新手,也会出自工作了好几年的老程序员手下。因此本文的目的在于帮助那些没有养成良好的编码风格,缺乏相应编码规范意识的JavaScript学习者们改善他们的编码形象。
编码形象
以上我提出了编码形象的概念,我个人认为:
编码形象 = 编码风格 + 编码规范
一个良好的编码形象就等于一个穿着得体的青年,对于程序员来说这是同行了解你优秀能力的最直接最简单的方式。
我们来看一下一段糟糕的编码形象:
//打个招呼
function func(){
var age=18,sex='man';
var greeting='hello';
if(age<=18&&sex=='man'){
console.log(greeting+'little boy')
}
...
}
func()
上方代码整体缩在了一起,缺乏规范意识,阅读体验很差,不忍直视。
再来看一段良好的代码形象:
// 打个招呼
function greetFn() {
var age = 18,
sex = 'man',
greeting = 'hello';
if (age <= 18 && sex === 'man') {
console.log(greeting + 'little boy');
}
...
};
greetFn();
上方的代码是不是感觉舒服多了?
由此可见养成一个良好的编码形象是至关重要的,而本文主要讲解的是基于JavaScript的编码形象,即基于JavaScript的编码风格和编码规范。
那么什么是编码风格,什么是编码规范,两者的区别又是什么?
编码风格
首先编码风格既然是风格,就没有对错之分。就好比每个人的穿着打扮不同,有的人穿的比较得体,有的人穿的比较随意而已。
而在JavaScript编码风格中,也有一套比较得体的风格,尤其在团队开发中,我们不能随意的书写属于自己的风格。
下面就列举几种随意的编码风格,并将其与良好的编码风格进行对比。
1.合理注释
// 不推荐的写法
var name = '劳卜';//代码和注释之间没有间隔
if (name) {
/*
*注释之前无空行
*星号后面无空格
*/
}
// 推荐的写法
var name = '劳卜'; // 代码和注释之间有间隔
if (name) {
/*
* 注释之前有空行
* 星号后面有空格
*/
}
2.合理间隔
// 不推荐的写法
var name='劳卜'; // 等号和两侧之间没有间隔
// if块级语句间没有间隔
if(name){
console.log('hello');
}
// 推荐的写法
var name = '劳卜'; // 等号和两侧之间有间隔
// if块级语句间有间隔
if (name) {
console.log('hello');
}
3.合理缩进
// 不推荐的写法:没有合理缩进
function getName() {
console.log('劳卜');
}
// 推荐的写法:合理缩进
function getName() {
console.log('劳卜');
}
4.合理空行
// 不推荐的写法: 代码功能块之间没有空行
function getName() {
var name = '劳卜';
if (name) {
console.log('hello');
}
}
// 推荐的写法:代码功能块之间有空行
function getName() {
var name = '劳卜';
if (name) {
console.log('hello');
}
}
5.合理命名
// 不推荐的写法
var getName = '劳卜'; // 变量命名前缀为动词
// 函数命名前缀为名词
function name() {
console.log('hello');
}
// 推荐的写法
var name = '劳卜'; // 变量命名前缀为名词
// 函数命名前缀为动词
function getName() {
console.log('hello');
}
6.合理声明
// 不推荐的写法:函数在声明之前使用
getName();
function getName() {
console.log('hello');
}
// 推荐的写法:函数在声明之后使用
function getName() {
console.log('hello');
}
getName();
7.合理结尾
// 不推荐的写法:没有使用分号结尾
var name = '劳卜'
var getName = function() {
console.log('hello')
}
// 推荐的写法:使用分号结尾
var name = '劳卜';
var getName = function() {
console.log('hello');
};
以上主要列举了7个比较常见的编码风格的例子进行了比较,在推荐的写法和不推荐的写法中两者并没有对错之分,只是推荐的写法相比较而言更容易阅读和维护,更适用于团队开发,也是良好编码形象的体现。
编码规范
对于编码规范,既然是规范,那我们就应该按照一定的规则来编写。随意编写违反编码规范的代码,可能会导致程序的出错和潜在的bug,因此其相对于编码风格来说应该更加严谨,也有人会把编码风格包含在编码规范之中。
下面就列举几个常见的实例代码:
1.比较参数
// 不推荐的写法:==和!=比较时会进行类型转换,应尽量避免使用
var num = 123;
if (num == '123') {
console.log(num);
} else if (num != '321') {
console.log('321');
}
// 推荐的写法:使用===和!==来进行比较
var num = 123;
if (num === '123') {
console.log(num);
} else if (num !== '321') {
console.log('321');
}
2.包裹if语句
// 不推荐的写法:if语句不用大话号包裹会出现潜在bug var num = 123; if (num === '123') console.log(num);
// 推荐的写法:if语句用大话号包裹
var num = 123;
if (num === '123') {
console.log(num);
}
3.慎用eval
// 不推荐的写法:应避免使用eval,不安全,非常耗性能(一次解析成js语句,一次执行)
var json = '{"name": "劳卜", "func": alert("hello")}';
eval('(' + json + ')'); // 弹出“hello”
// 推荐的写法
var json = '{"name": "劳卜", "func": alert("hello")}';
JSON.parse(json); // 校验报错
4.判断类型
// 不推荐的写法:用typeof来判断构造函数创建的对象
var str = new String('劳卜');
console.log(typeof str); // 'object'
// 推荐的写法:用instanceof来判断构造函数创建的对象
var str = new String('劳卜');
console.log(str instanceof String); // true
5.检测属性
// 不推荐的写法:使用undefined和null来检测一个属性是否存在
if (obj['name'] !== undefined) {
console.log('name属性存在'); // 若obj.name为undefined时则会导致判断出错
}
if (obj['name'] !== null) {
console.log('name属性存在'); // 若obj.name为null时则会导致判断出错
}
// 推荐的写法:使用in运算符来检测对象属性是否存在,使用hasOwnProperty方法来检测不包含原型链上的对象属性是否存在
if ('name' in obj) {
console.log('name属性存在');
}
if (obj.hasOwnProperty('name')) {
console.log('name属性存在');
}
以上主要列举了5个常见的编码规范的例子,合理地规范自己的代码能够很大程度上减少不必要的维护成本和潜在的bug风险,对于JavaScript学习者来说应该铭记于心。
结语
“程序是写给人读的,只是偶尔让计算机执行一下。”我们不能为了贪图一时的方便而亲手毁了自己的代码形象,这会给他人和整个项目带来不必要的麻烦。
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持!
# javascript编码规范
# javascript编码
# javascript技巧
# 前端编码规范(3)JavaScript 开发规范
# 最全的Javascript编码规范(推荐)
# Node.js编码规范
# JavaScript之编码规范 推荐
# 浅谈JavaScript编程语言的编码规范
# JavaScript 程序编码规范
# 自己的
# 是否存在
# 打个
# 有的人
# 之分
# 举了
# 的是
# 时则
# 这是
# 他们的
# 几个
# 让人
# 也有
# 也会
# 又是
# 给他
# 每个人
# 阅读者
# 而在
# 适用于
相关栏目:
【
网站优化151355 】
【
网络推广146373 】
【
网络技术251813 】
【
AI营销90571 】
相关推荐:
敲碗10年!Mac系列传将迎来「触控与联网」双革新
如何在局域网内绑定自建网站域名?
免费网站制作appp,免费制作app哪个平台好?
谷歌Google入口永久地址_Google搜索引擎官网首页永久入口
Laravel的.env文件有什么用_Laravel环境变量配置与管理详解
PHP 500报错的快速解决方法
JS经典正则表达式笔试题汇总
js实现点击每个li节点,都弹出其文本值及修改
Python自动化办公教程_ExcelWordPDF批量处理案例
Laravel怎么生成二维码图片_Laravel集成Simple-QrCode扩展包与参数设置【实战】
Laravel如何保护应用免受CSRF攻击?(原理和示例)
如何用PHP工具快速搭建高效网站?
linux top下的 minerd 木马清除方法
Bootstrap整体框架之JavaScript插件架构
如何用ChatGPT准备面试 模拟面试问答与职场话术练习教程
高端云建站费用究竟需要多少预算?
如何在万网自助建站平台快速创建网站?
Linux系统命令中tree命令详解
如何在云指建站中生成FTP站点?
谷歌浏览器如何更改浏览器主题 Google Chrome主题设置教程
如何制作新型网站程序文件,新型止水鱼鳞网要拆除吗?
,南京靠谱的征婚网站?
Laravel如何实现API速率限制?(Rate Limiting教程)
无锡营销型网站制作公司,无锡网选车牌流程?
Laravel怎么使用Session存储数据_Laravel会话管理与自定义驱动配置【详解】
Laravel Debugbar怎么安装_Laravel调试工具栏配置指南
logo在线制作免费网站在线制作好吗,DW网页制作时,如何在网页标题前加上logo?
Laravel如何生成URL和重定向?(路由助手函数)
怎么制作网站设计模板图片,有电商商品详情页面的免费模板素材网站推荐吗?
Laravel如何配置和使用队列处理异步任务_Laravel队列驱动与任务分发实例
Laravel事件和监听器如何实现_Laravel Events & Listeners解耦应用的实战教程
如何用VPS主机快速搭建个人网站?
Windows Hello人脸识别突然无法使用
如何快速搭建高效WAP手机网站?
百度输入法全感官ai怎么关 百度输入法全感官皮肤关闭
Swift中循环语句中的转移语句 break 和 continue
Swift开发中switch语句值绑定模式
INTERNET浏览器怎样恢复关闭标签页_INTERNET浏览器标签恢复快捷键与方法【指南】
Laravel Eloquent关联是什么_Laravel模型一对一与一对多关系精讲
Laravel如何使用Contracts(契约)进行编程_Laravel契约接口与依赖反转
Laravel Eloquent模型如何创建_Laravel ORM基础之Model创建与使用教程
使用C语言编写圣诞表白程序
如何在云主机上快速搭建多站点网站?
Python文件操作最佳实践_稳定性说明【指导】
WordPress 子目录安装中正确处理脚本路径的完整指南
Java Adapter 适配器模式(类适配器,对象适配器)优缺点对比
如何在建站之星绑定自定义域名?
矢量图网站制作软件,用千图网的一张矢量图做公司app首页,该网站并未说明版权等问题,这样做算不算侵权?应该如何解决?
用yum安装MySQLdb模块的步骤方法
悟空识字如何进行跟读录音_悟空识字开启麦克风权限与录音

