让 JavaScript 更有趣的技巧
目前golang学习网上已经有很多关于文章的文章了,自己在初次阅读这些文章中,也见识到了很多学习思路;那么本文《让 JavaScript 更有趣的技巧》,也希望能帮助到大家,如果阅读完后真的对你学习文章有帮助,欢迎动动手指,评论留言并分享~
编码可能是最有价值和最具创造性的工作之一,但说实话,它有时也可能让人不知所措、失去动力,甚至完全令人沮丧。多年来,我个人一直在与无聊、任务不堪重负和完美主义兔子洞作斗争。无论您是在从事业余项目、与团队合作还是应对专业挑战,这些技巧都旨在帮助您使编码变得更易于管理、更高效,而且最重要的是,更有趣。虽然我将使用 javascript 作为这些想法的镜头,但它们是普遍适用的。
0. 将项目分解为尽可能小的可交付成果
首先将您的项目分解为可实现的小块。定义每项可交付成果的绝对最小范围,并仅关注正在进行的交付成果。这种方法不仅可以避免事情让人感到不知所措,还可以让您庆祝一路上的小胜利,并从最终用户或利益相关者那里获得见解。
1.先写类型
如果您使用 typescript 或类似工具,首先定义类型可以作为代码的路线图。即使在纯 javascript 中,预先绘制数据结构或接口也可以在以后节省大量时间。此外,这些类型可用于生成用于测试、故事书故事的模拟数据,或在开发系统的其他部分时直接生成模拟数据。
那些更喜欢使用原始 javascript 而不是 typescript 的人仍然可以在 jsdoc 中编写类型:
/** * @typedef {object} task * @property {string} id - the unique identifier for the task. * @property {string} title - the title of the task. * @property {string} description - a detailed description of the task. * @property {boolean} iscompleted - indicates whether the task is completed. */ /** * adds a task to the task list. * * @param {task} task - the task to be added. * @returns {boolean} - returns true if the task was added successfully. */ function addtask(task) { // logic to add the task console.log('task added:', task); return true; }
2.使用测试标题作为待办事项列表
测试驱动开发 (tdd) 不仅仅关乎质量;还关乎质量。它也是生产力的助推器。编写描述性测试标题,作为实施的清单 - 就像将待办事项列表直接构建到工作流程中一样。例如:
// File: user.test.js describe('User Management', () => { it.todo('should create a new user'); it.todo('should fetch a user by ID'); it.todo('should update user details'); it.todo('should delete a user'); });
这种方法可以让您保持井井有条,同时为需要完成的工作提供清晰的轮廓。
3. 首先做能带来最大价值的事情
从影响最大的功能或任务开始。这种优先顺序可以激励您并创造动力,尤其是当利益相关者或团队成员立即从可见的进展中受益时。
例如,如果您的应用程序的核心功能是视频处理,那么您应该首先关注它。可以在稍后阶段添加用户管理,并且在此之前可以通过基本身份验证来保护网站。
4. 编写你能想到的最简单的代码
始终编写最简单的代码来完成所需的任务,仅此而已。代码是可以改变的,并且随着需求的发展自然会变得更加复杂。一开始试图让它看起来聪明或复杂往往会适得其反。智能代码非常简单——随着时间的推移,调试、审查和适应变得更加容易。
5. 对工具、库和框架很挑剔
在选择外部依赖项时,优先考虑开发人员经验、项目适合度和质量,而不是受欢迎程度。你听说过关于 node_modules 是宇宙中最重的物体的大胡子笑话吗?不仅重,而且重。外部代码通常很难适应或修改,因此彻底审查和测试工具至关重要。如果您自己的实现更值得信赖或更适合您的项目,那么编写自己的实现是完全可以的。同时,如果外部工具和库能带来真正的好处,就不要害怕使用它们。只要确保您的项目不会变得如此依赖它们,以至于以后解开它们将需要全面的“凝固汽油弹重构”。
6. 使用提交来记录你的决定
将您的 git 提交视为您旅程的日志。每次提交不仅应该捕获代码更改,还应该捕获它们背后的原因。这使得未来的调试和协作变得更加容易。考虑采用传统提交来维护一致且描述性的提交历史记录。例如,像 feat:、fix: 或 chore: 这样的前缀有助于阐明每个更改的目的并提高可读性。
7. 边走边重构
不要把所有重构都留到最后。实施过程中的小规模增量改进不会那么令人生畏,并且有助于维护高质量的代码库。根据经验,如果您现在可以重构而不会对当前任务产生太大影响,那就去做吧。否则,请留下 // todo: 注释、创建任务或找到其他方法来确保您在时间允许时返回该任务。
8.定期自我检查你的代码
在考虑完成之前先退后一步阅读并批评您的代码。这个习惯可以发现不一致的地方并改进你的工作——就像校对一篇文章一样。最简单的方法是在第一次提交后立即打开草稿 pull 请求。
9.尽早并经常寻求反馈
不要等到你的工作“完成”才让其他人参与。结对编程是获得即时反馈和分享知识的绝佳方式,但即使是同事的早期审查也可以节省时间并提高质量。
最后,要记住的最重要的提示是,没有完美的代码或完美的流程也没关系。在一些代码之后甚至稍后编写测试是完全可以的。偶尔错过一个错误是很正常的。只要您的代码和创作随着时间的推移变得更好并且您玩得很开心,一切都是允许的:毕竟,编程应该与您用它创建的解决方案一样有价值!
以下哪些提示对您来说是显而易见的?您发现哪些富有洞察力?您有什么建议想分享吗?请在评论中告诉我。
本文的草稿和封面图片是在 ai 的帮助下创建的
以上就是本文的全部内容了,是否有顺利帮助你解决问题?若是能给你带来学习上的帮助,请大家多多支持golang学习网!更多关于文章的相关知识,也可关注golang学习网公众号。

- 上一篇
- 2024年我国规上工业增加值同比增长5.8%

- 下一篇
- 证监会:“释放利空”相关传言是谣言
-
- 文章 · 前端 | 7分钟前 |
- CSS弹性布局移动端适配全攻略
- 116浏览 收藏
-
- 文章 · 前端 | 49分钟前 |
- CSS按钮悬停动画教程实战详解
- 137浏览 收藏
-
- 文章 · 前端 | 58分钟前 |
- JavaScript计时器不更新?检查DOM元素!
- 453浏览 收藏
-
- 文章 · 前端 | 1小时前 | flex属性 自动换行 align-content CSS弹性布局 flex-wrap:wrap
- CSS弹性布局自动换行技巧
- 442浏览 收藏
-
- 文章 · 前端 | 1小时前 |
- Tailwind布尔状态样式失效解决方法
- 329浏览 收藏
-
- 文章 · 前端 | 1小时前 |
- JS继承原理与实现方式解析
- 240浏览 收藏
-
- 文章 · 前端 | 1小时前 |
- PuppeteerHeroku运行中断解决方法
- 156浏览 收藏
-
- 文章 · 前端 | 1小时前 |
- CSS背景图不显示怎么解决
- 355浏览 收藏
-
- 文章 · 前端 | 1小时前 |
- React与Redux共享数据的实用技巧
- 283浏览 收藏
-
- 文章 · 前端 | 1小时前 |
- ES6Promise如何避免回调地狱
- 340浏览 收藏
-
- 文章 · 前端 | 2小时前 |
- HTML如何添加地图标记点?
- 102浏览 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 499次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 484次学习
-
- PandaWiki开源知识库
- PandaWiki是一款AI大模型驱动的开源知识库搭建系统,助您快速构建产品/技术文档、FAQ、博客。提供AI创作、问答、搜索能力,支持富文本编辑、多格式导出,并可轻松集成与多来源内容导入。
- 55次使用
-
- AI Mermaid流程图
- SEO AI Mermaid 流程图工具:基于 Mermaid 语法,AI 辅助,自然语言生成流程图,提升可视化创作效率,适用于开发者、产品经理、教育工作者。
- 858次使用
-
- 搜获客【笔记生成器】
- 搜获客笔记生成器,国内首个聚焦小红书医美垂类的AI文案工具。1500万爆款文案库,行业专属算法,助您高效创作合规、引流的医美笔记,提升运营效率,引爆小红书流量!
- 875次使用
-
- iTerms
- iTerms是一款专业的一站式法律AI工作台,提供AI合同审查、AI合同起草及AI法律问答服务。通过智能问答、深度思考与联网检索,助您高效检索法律法规与司法判例,告别传统模板,实现合同一键起草与在线编辑,大幅提升法律事务处理效率。
- 892次使用
-
- TokenPony
- TokenPony是讯盟科技旗下的AI大模型聚合API平台。通过统一接口接入DeepSeek、Kimi、Qwen等主流模型,支持1024K超长上下文,实现零配置、免部署、极速响应与高性价比的AI应用开发,助力专业用户轻松构建智能服务。
- 959次使用
-
- 优化用户界面体验的秘密武器:CSS开发项目经验大揭秘
- 2023-11-03 501浏览
-
- 使用微信小程序实现图片轮播特效
- 2023-11-21 501浏览
-
- 解析sessionStorage的存储能力与限制
- 2024-01-11 501浏览
-
- 探索冒泡活动对于团队合作的推动力
- 2024-01-13 501浏览
-
- UI设计中为何选择绝对定位的智慧之道
- 2024-02-03 501浏览