IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> 前端开发应该掌握的一些提高代码质量的小知识 -> 正文阅读

[JavaScript知识库]前端开发应该掌握的一些提高代码质量的小知识

????????本文章会实时更新一些常用的小技巧,如果大侠读起来还算满意的话,望您给个赞,收藏一下方便您随时浏览;

1. 在项目中使用 Object?.key?去代替?Object.key ,抛弃 && 和 三目?这些冗余的写法

????????原因:为什么要这么做呢,相信很多小伙伴也遇到过类似的问题,跟后台对一个接口,数据是Object类型的,ok,开发完成上线后,呀, 怎么报错了, 原来没返回这个字段,或者返回了个 null ,?没错,你可能会说跟后端说一下就好了,但是求人不如求己, 我们大前端从不屈服于别人!

? ? ? ? 原理这里的 ?. 相当于一个链式调用前的一个判断,会先去判断前面是否为真,为真继续往下执行, 为假则中止;

? ? ? ? 废话不多说,使用方法的代码如下:

// 此处模拟下obj是后台接口返回的字段, 定义类型为Object
function handle (obj) {
    console.log(obj.a.b)  // 错误的用法
    console.log(obj?.a?.b)  // 正确的用法
}

// 正常情况下
handle({
    a: {
        b : 1
    } 
})

// 特殊情况下
handle({})

2. 字符串的替换使用 replaceAll 方法替代 replace 方法

? ? ? ? 原因:没错,String.prototype 上再次新增一员大将,顾名思义,replaceAll可以一次替换字符串中所有满足条件的部分,再也不需要麻烦的正则写法了,看来还是程序员懂程序员啊,代码当然是越简单越好了!

? ? ? ? 原理相当于replace加正则的全部匹配

????????废话不多说,使用方法的代码如下:

const str = 'abcdabcdabcd';

// 在这之前的写法 替换处理
str.replace(/c/g, 's');

// 新的写法 替换处理
str.replaceAll('c', 's');

3. 用 ?? 去做精准的运算判断处理,代替了 || 运算符

? ? ? ? 原因:相信大家在日常的代码书写当中经常会用到 &&? ||? 这两种非常好用的运算符,今天就给大家介绍一种比较好用的运算符,它类似? || ,但又有所不同,能够处理更为精准的运算需求;

? ? ? ? 原理:?? 运算符只有当左侧围 null 或者 undifined 时才会进行右侧的运算,没错相比于 || 只要左侧为前端意义上的 'false' 不同,这里的对于类型的判断更为严谨;

????????废话不多说,使用方法的代码如下:

const isRunRightCode = {
    old_yes: [ 0, false, '', undefined, null ],
    old_no: [ 1 ],  // 任何 判断后布尔值为true的都会直接输出,不运行右侧代码
    new_yes: [ undefined, null ],
    new_no: [ 0, 1, false, '' ]
}

// 此处不一一举例,一个数组中的数据达到的效果是一样的,只是为了让大家能更好的区分

//              运算                                        结果(输出右面 或者 未输出右面)
// || 运算符的运用
console.log( isRunRightCode.old_yes[0] || '输出右面' )    //  输出右面
console.log( isRunRightCode.old_no[0] || '输出右面' )    //  输出右面


// ?? 运算符的运用
console.log( isRunRightCode.new_yes[0] ?? '输出右面' )    //  输出右面
console.log( isRunRightCode.new_no[0] ?? '输出右面' )    //  输出右面

  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2022-09-15 01:54:56  更:2022-09-15 01:58:06 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/26 4:59:29-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码