首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
您找到你想要的搜索结果了吗?
是的
没有找到

让你的 JS 代码变得更加优雅且维护

枚举 对于上面判断 userRole 的代码,其实我们可以用更优雅的方式去实现,那就是 枚举 。...上面的代码依旧是优化的,在这里我们可以利用策略模式来做进一层的优化。...更在状态 除了上面的方式之外,我们还可以利用“ 状态 ”的概念来写代码。在看代码之前,我们先了解下什么是 “有限状态机”。...不同的状态展示的 UI 也不同,所以我们以不同的状态划分好模块之后,代码写起来就会清晰很多,我们以 Vue 代码为例: // contants.js export const ORDER_STATUS...上面这段文字估计没有什么人看,算了,直接上代码吧 ? 我们看回上面打工人的场景,假定老板想要知道打工人每个状态开始前跟结束前的时间以及做点什么,那么该怎么做呢?

91110

代码质量--重用代码

重用的代码指:在相似业务场景下,用的是同一份代码重用的代码可以减少重复劳动。一个软件中,会有很多类似的业务场景。将这些场景抽象成重用的代码。开发新功能时,重用代码减少重复劳动。...如果做成重用的,则只需改动一处。 一、如何写出重用的代码 代码块的职责越多,越难被复用。写出重用的代码就是:识别,分离出复用的部分。...具体接口的调用 接口调用代码一般会放在一个文件中,如service.js: export const fetchList = ... export const fetchDetail = ... export...Lodash和 moment.js包含了很多的工具方法。 二、总结 要写出重用的代码,本质就是识别和分离出复用的部分。前端可以从UI展示,接口调用,业务流程,数据,工具函数中找出复用的部分。...代码质量的下一层次就是:重构的代码。我会在下一篇文章中介绍。

14130

维护代码有感

维护代码的数量指标跟代码可维护性密切相关,项目代码可维护性不仅仅对自己,更多的还是对其他陌生人(其中包括对自己代码已经陌生的自己)。当我们编写软件代码时,一个重要的目标是让代码易于维护。...测性 代码测性(testability)是指代码的易测性、测性,是指在设计和编写应用程序时,将测试考虑在内,使得程序更易于测试和测试效率更高。...拓展性 代码拓展性是指代码能够在未来增加新功能、应对需求变化、适应新技术和平台等要求时,能够快速而又有效地进行修改和扩展的能力。...在当今的软件开发行业中,代码拓展性已经成为了一个非常重要的需求和评估标准。具有良好拓展性的代码可以更容易地满足用户的需求,同时也可以大大减少业务需求的变化对代码的影响,减少维护成本和开发周期。...此外,一旦建立具有良好拓展性的代码结构,其设计和代码都可以轻松地重复利用,从而减少重复编写代码的风险和成本,增加稳定的开发基础。具备良好拓展性的代码也可以提高其可维护性。

17720

百度上线轻量级链接提交组件 自动推送JS代码

百度上线轻量级链接提交组件 自动推送JS代码 ---- 百度站长平台发布公告表示,已推出JS自动推送工具。据悉,使用JS代码自动推送工具有利于新页面更快的被百度发现。...站长只需一次部署自动推送JS代码的操作,就可以实现新页面被浏览即推送的效果,低成本实现链接自动提交。对于已经使用主动推送的站点,也可以部署自动推送的JS代码,二者不会有影响。...自动推送代码如何安装使用? 站长需要在每个页面的HTML代码中包含以下自动推送JS代码当页面被访问时,页面链接会自动推送给百度,有利于新页面更快被百度发现。...”的文件,文件内容是上述自动推送JS代码; 2、在每个PHP模板页文件中的 标记后面添加一行代码: <?...如若本站内容侵犯了原著者的合法权益,联系我们进行处理。

1.1K30

SOLID 原则:编写扩展且维护的代码

它违反了职责分离的原则,并使代码的灵活性和扩展性降低。让我们看一下解决这个问题的一种方法。...但是,如果我们添加了 Bicycle(自行车)类。显然我们将无法再启动发动机,因为自行车没有发动机。下面演示了解决此问题的错误方法。...class Bicycle(Vehicle): def ride(self): # 骑自行车 print("Riding the bike.")...SOLID 原则是一组编程设计原则,旨在提高软件的扩展性、可维护性和质量。它们分别是: 单一职责原则SOLID原则:一个类或模块应该只有一个职责,且该职责应该由该类或模块完全封装。...通过遵循这些原则,我们可以编写出更加清晰、灵活和复用的代码,降低耦合度和代码腐化的风险,提高代码测试性和可读性。

17720

调试JS代码

记录下近期对JS代码的调试过程 性能分析 启动程序之后,打开google浏览器对应页面,按F12或者Ctrl+Shift+I进入 开发者工具页面 目前主要使用的功能有: Performance....性能评估,比如我想看下页面刷新的性能瓶颈所在,先点击 按钮,然后进行页面操作,当页面刷新完成,再点击 按钮,则会生成性能报告,可以看到资源消耗,JS代码的执行逻辑等 Sources....性能报告页面的 部分,可以通过点击色块查看其所在的js代码文件,如 点击则会跳转到 功能栏,有了源文件就可以进行断点调试;这里注意部分js文件是压缩后的文件,建议手动修改程序替换成可读性更强的原始代码文件...查看程序的打印输出,比如我想知道某个函数的执行时间,可以在js代码中进行修改 当js代码执行之后,可以在console输出中看到foo的执行时间 Network....代码使用for循环进行操作,也就是线性复杂度,计算耗时随数据量的增大而线性增大 通过debug观察发现颜色数组会有不少重复的数值,而同样的输入会导致相同的输出,然后对整个数据的1M个点进行统计分析,发现重复率相当高

19K10

js代码规范

前言 在js代码开发中,我简单的总结出了以下规则,后面会陆续补充并且对规范进行分类。...js代码建议保存到后缀名.js的文件中 js代码不建议放在html中,原因有:不能被缓存,会增大网页文件的大小,可维护性不高,会影响页面的加载。...js吧任何表达式都当一条简单语句,会导致一些隐性的错误。如果自己没加分号,那么js解释器会自动添加分号,按照自己能读懂的断句。 9.2 复合语句 也称为语句块,被包在大括号内部。...比如对象 var obj={} ;var arr=[] eval eval是最容易混乱使用的js函数,他可以执行内部入参的js函数或者表达式,可以直接解析变量。不建议使用 。...尽量使用语法严格模式 消除代码之中的不友好;代码运行更快 ;保证运行的安全 ;为新版本的js做好铺垫。 22.

8.8K30

JS代码混淆 | js 逆向系列

-g uglifyjs example.js -c -m --mangle-props -c 代码压缩 -m 代码混淆 --mangle-props 混淆属性名 -b 美化显示 // 原代码 const...JShaman https://www.jshaman.com/ JShaman 是国内公司开发的js代码加密商业产品 免费版可以直接使用 // 原代码 const person = { age...,通过数组、字典等各种形式存储、拼接、替换等,最终进行还原,这里面没有利用到复杂的语法以及js 语言本身的特性,所以我们一点点解开也学不到什么; 这个代码就不一样了,我们一步一步解开它,尝试去学习其中的思路....+)+)+)+$')['toString']()['constructor'](a)['search']('(((.+)+)+)+$');});a();console['log'](0x7b); 代码正常运行...源映射帮助您调试混淆的 JavaScript 源代码。如果您想要或需要在生产中进行调试,您可以将单独的源映射文件上传到一个秘密位置,然后将浏览器指向那里。

1.4K10

JS|JavaScript脚本也固定位置

问题描述 “如果不改变标签的位置,如何固定JS的脚本呢”,当我们在网页中写入JavaScript代码时,如果我们每次都必须在其他标签之后嵌入JavaScript代码,不仅会造成代码的冗余...,而且也不方便我们检查代码,同时也会增加我们的工作量。...我们是通过window的页面初始化事件处理函数,我们通过这个函数来执行下面的代码,通过函数的调用来执行下面的js代码,这句代码在刚开始是不会执行的,当页面完全加载完毕后才会调用js代码。...这样我们保存之后再运行我们就会发现js代码生效了。 结语 我们在写JavaScript脚本时一定要注意代码位置,注意代码的解析顺序及其对象的属性。...如果想要其位置固定就需定义相应函数来调用其js代码让其生效。我们在定义函数时一定要注意其符号必须是英文状态下的符号,否则会产生解析错误。

2.9K20

编写测试的JavaScript代码

B.代码是让人用的 1.我们编写的代码不是让电脑用的,而是让人用的 2.为何要编写测试的代码 测试的代码更加容易测试,意味着它更加容易维护,易维护则意味着它有让人(包括自己)更加容易理解 ,更加容易维护...,从而又使得测试变得更加容易 3.如果没有测试的、维护的以及可理解的代码,那它就是垃圾 4.什么是测试的代码 什么是测试:短小但也不太复杂的代码、完整的注释,以及检耦合。...什么是维护:可以存在于一个完整的产品周期:产品从一个人转到另外一个人手里时,不需要部分或全部重写 什么是可理解:简单的、小型的且有注释的代码更加容易理解 5.如何编写测试的代码:编写短小、最小依赖和最低复杂度的隔离的代码块...①程序特定:我们自己编写的代码 ②领域特定:在程序中使用的第三方模块 ③领域独立:类似YUI这样的框架或Node.js 3.如果发现代码被编写了两遍,那就是时候将其提取到函数中了。...2.该架构发挥了JS函数的优势,鼓励使用最小依赖项的小型耦合代码。鼓励开发人员编写使用最小依赖项的小块代码,使用事件而不是方法调用,可以极大地提高测试性和可维护性。

1.3K30
领券