首页
学习
活动
专区
圈层
工具
发布

我正在使用中的博客创作工具

访问我的博客 www.fatbobman.com[1] 可以获得更好的阅读体验 从 2020 年 4 月开始,截至本月,我的博客【肘子的 Swift 记事本】已创建 2 年了。...这期间,使用过不少的工具以协助博客的创作。本文将对我正在使用中的应用工具(包含资料收集整理、文本编辑、截图及录屏、格式转换、图片编辑、图床管理等方面)做以介绍。...无论是做学习笔记还是知识整理,几年来,我在 OneNote 中记录、整理了不少的内容。...遗憾的是 macOS 版本无法使用 markdown 插件,因此我会以截图的方式记录代码片段(此种方式对空间的占用较大,幸好 OneDriver 提供了 1TB 的容量),并将保存完整的源代码文件以附件的形式添加在笔记中...不过由于缺乏定制能力,我几乎不会使用它的 Gif 动图录制功能。

1.4K20

从 React 源码的类型定义中,我学到了什么?

今天看了下 React 的类型定义,也就是 @types/react 包下的 index.d.ts,发现了一些有趣的写法。...然后我就看到了这样一段注释: 在 ts 3.0 中,如果索引类型没有对应的索引,那返回的类型是 {} 而不是 never。...T : never; 测试下: Exclude Exclude 是从联合类型 A 中去掉联合类型 B 中的类型,也就是取差集: type Extract = T extends U ?...这个我确实想了一段时间,如果 { a: 1, b: 2} 这样的索引类型,keyof 的结果是 'a' | 'b',而如果是数组类型,那 keyof 的结果是 0 | 1 | 'length' | 'toString...总结 我看了下 @types/react 的类型定义,学到了不少东西: 可选索引的值的提取,用 infer 比 Obj[key] 更方便,因为前者只需要 Obj[Key] extends { xxx?

1.4K11
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    这些前端技术,我学了就后悔!不要重蹈我的覆辙(网友投稿)

    从2015年入坑到现在,我踩过的那些技术大坑全曝光 还记得2015年刚入坑前端时的我吗?像个饥饿的海绵,疯狂吸收一切能找到的教程、博客和视频。那时天真地以为:学得越多 = 技术越强。 结果呢?...Ruby on Rails:曾经的王者,如今的遗老 入坑原因:那时候Rails还挂着"快速开发神器"的光环现实打击:工作这么多年,连一个生产环境的Rails项目都没碰过 2015年的时候,Rails确实很火...DHH(Rails创始人)的理念听起来很美好:Convention over Configuration(约定优于配置)。我花了好几个月时间啃Rails教程,搭建各种Demo项目。...选择建议:前端三大框架React、Vue、Angular已经形成稳定格局,新手没必要尝试小众框架。...函数组件 + Hooks的组合不仅代码更简洁,逻辑复用也更灵活。 血泪教训:即使是同一个框架内部,也要选择最现代的写法。过时的API学了也是负担。

    17610

    vue-cli

    为了避免陷入细节泥潭,我会尽量使用图形化方式展示他们程序流程,避免拘泥于细节。你也可以把这些文章作为深入阅读这些项目源码的引导 我也希望读者同我交流反馈,共同学习和进步。...Rails 有一个重要的指导思想,即约定大于配置, 它为 Web 应用的大多数需求都提供了最好的解决方法,并且默认使用这些约定,而不是在长长的配置文件中设置每个细节。...笔者是使用 React 作为主力开发的,Vue 也是我非常喜欢的一个开源项目,不说别的,在开发者的’用户体验’方面 Vue 是我见过最好之一,主要体现在 API 的简洁性和易用性、文档还有项目构建工具(...进行扩展) 中(可以配置 babel,postcss,Typescript); 提供了 Node API; 支持插件扩展文件类型 多页面 支持 - 支持 适用范围 Vue 组件的第一公民。...: 验证 npm 包名称,比如创建的项目名是否合法 dotenv & dotenv-expand: 从.env 文件中加载配置,环境变量 网络相关 portfinder: 获取可用的端口 address

    4K10

    JavaScript 生态系统非常奇怪

    我之前提到过 Rails 因为使用元编程而受到很多批评。但是大多数人对上述 JavaScript 语言的任何 “滥用” 都视而不见。JavaScript 生态系统就像是一个大帐篷派对。...虽然 JSX 通常会编译成 JS,但 Server React DOM API 支持编译成 HTML 。RSC 采用了不同的方式,并编译成了标记的 JSON 流。...许多人将其与 PHP 甚至 Rails 进行比较: 我不确定这些比较是不是意味着更积极的方式,但我会说从我的角度来看,这是一件非常好的事情。...从 fly.io 的角度来看,RSC 实现的更新(重新获取)序列是非常有趣的。...他甚至设法在使用该操作系统和浏览器组合的情况下完成了十个步骤中的九个。 但是这个演讲中令人费解的部分是他首先利用 use server 来实现客户端表单操作,然后才使用 use client.

    79430

    Strikingly 团队2017技术展望

    在这个应用的开发过程中,我们把 native 和 web 可以共用的代码,包括业务逻辑和通用的工具辅助类代码从原来的 React Web 代码里抽出来,放到 common 目录下方便 native 和...从最初听到 Facebook 的工程师畅想着通过 React 可以开发不同平台应用到现在我们团队已经实现了这个目标,我很庆幸这是客户端工程师一个美好的时代。...服务端只需要定义好业务逻辑中设计的数据类型系统,客户端工程师就可以使用 GraphQL 自定义查询的数据及其结构,大大地提升了 API 的灵活性。...要解决这问题,我们需要重新审视 Rails 在 Web 应用开发中的定位。Rails 只是一个 Web 框架,它不是一个应用开发框架,不能也不应该负责 Web 应用中领域相关的部分。...首先,手动操作容易造成操作错误,尤其是在维护正在运行应用的基础设施的过程中,如果不小心关掉了某台服务器或者设置网络的时候规则设置错误,都可能造成服务中断,影响用户使用。 其次,手动操作效率比较低。

    2.7K00

    你不知道的 React 最佳实践

    React 使用 key 属性跟踪数组中的每个元素,这是由于数组具有折叠特性。...毫无例外, 从应用程序中移除注释功能意味着我必须根据注释逐行编写额外的代码。...因为函数组件不需要 this 绑定,所以只要有可能就要使用它们。 但是如果您正在使用 ES6类,您将需要手动绑定这个类,因为 React 不能自动绑定该组件中的函数。 这里有一些这样做的例子。...在下面的代码片段中,您可以看到分配给 ModalButton 的 props 的所有默认值。 在本例中,我使用了 React Bootstrap 框架。...图片 如果你使用开发者工具正在寻找一个使用 React 中的 Web 应用程序,您可以在 Components 选项卡中看到组件层次结构。

    4K10

    DHH:2017年Rails 框架还值得学习吗?

    这些年 JavaScript 世界有着大量的进步, 但我们也看到了倒退的世界, 而这些正在 Rails 前年就为大家解决掉了....通过它, 开发者可以获得巨大的生产力. 众多所知, Rails 也因此而获取得巨大的成功. 不过令我惊讶的是, 在这点上, 世界上竟然没有多少同类的竞争对手....我已经在其他地方进一步详细阐述了在Rails 核心原则中关于配置的约定方法, 以及点菜 / omakase冲突的说明, 和集成系统的吸引力以及 Rails 社区的其他核心价值....正如我上面提到的, Rails 有一个雄心勃勃的终极使命, 那就是站在全栈的角度下, 帮助开发者处理好过程中的每一块代码, 从连接到数据库, 到 nosql 数据存储, 到业务模型, 到控制器, 直到最后...而且, 最为重要的是, 我已经把 “樱桃” 留下了. 现在就开始使用 Ruby 吧. 就算这些年是人们重新发现函数式编程和不变性数据理念价值的时代, Ruby 仍然是我遇到过最漂亮, 最奢华的语言.

    2.9K90

    RadRails1.0降临——增加Profiler、CallGraph Analyzer和Rails Shell等新特性

    这里有一个RadRails、Netbeans和CodeGears的3rdRail的特性完全比较,从比较中可以看出RadRails在重构(refactoring)和性能剖析(profiling)方面更胜一筹...Christopher解释了这项支持目前的状态: 当前使用Rubinius作为启动Ruby进程的解释器还有诸多限制。当Rubinius成熟之时,就可以 使用它来尝试运行gems甚至Rails。...另外,很多用户正在使用Brad Wilson的HAML和SASS编辑器。不幸的是,最近的发布版破坏了其与RDT的集成,而且Brad没有时间来继续维护和改进。...我们正在和他一道将他的编辑器引入RadRails中,这样更有利于以后的维护和改进。...通过 DOM我们能够提供一个很小很简单的API,看上去很像Ruby API。 想尝试Aptana和RadRails 1.0或者只是想实际看看其特性的话,请看展示了大量特性的截屏视频。

    2.9K80

    如何编写漂亮的 React 代码?

    可以从我的代码与现实世界的交互中获得同等甚至更大的乐趣,我对此比较在乎。 结果是,尽管有时我发现一种编程语言、框架、工具不太好看或不好用,但我需要它来在合理的时间内让我的代码描述现实的某件事。...它的 React 版本带来了比 createElement 更吸引人的 API。...当试图发挥我的创造力去寻找不同的可能性时,这句话让我回到了十年前。我正在学习 Web 开发,而且刚刚碰到 Ruby on Rails。...就是那样,CoffeeScript 可以满足我的标准,因此我决定看看这个项目进展如何并尝试一下。...随着编译器的出现,使得每个人都可以使用甚至还不是标准的 JS 特性,即使是不得不支持旧浏览器的开发人员现在也可以从最新的语言特性中受益。这使得 CoffeeScript 的流行程度大不如前。

    1.4K10

    【Web后端架构】2022年10个最佳Web开发后端框架

    2022年的js需要一个资源,我推荐MERN堆栈从前到后:完整堆栈React、Redux和Node。...它是一个初学者友好的框架,具有用户友好的界面、广泛的库和出色的API支持。 使用Laravel可以简化后端开发,同时构建现代安全的web应用程序。如果您正在处理非平凡的应用程序,这一点尤其正确。...如果你想了解更多关于使用Golang和Fiber构建web应用程序的知识,我建议你加入Rob Percival和CodeStars在Udemy上的完整React&Golang课程。...这是一门基于项目的课程,你将使用React和Golang Fiber从头开始构建一个管理应用程序。...如果您是初学者,可以从Ruby on rails等对初学者友好的框架或Flask等轻量级框架开始。如果你热衷于学习最受欢迎的,那么你可以选择Spring Boot、Django或Express。

    5.8K20

    【译】开始学习React - 概览和演示教程

    经过几次失败的React入门尝试之后,我终于开始了解它了,我开始明白为什么我可能想使用React而不是原始的JS或jQuery。...state状态 现在,我们将字符数据存在变量的数组中,并将其作为props传递。这是一个很好的开始,但是请想象下,如果我们希望能够从数组中删除一个项目。...由于我们希望能够从表格中删除字符,因此我们将父App类上创建removeCharacter方法。 要检索状态,我们将使用与以前相同的ES6方法获取this.state.characters。...在渲染中,让我们从state中获取两个属性,并将它们分配为正确的表单键对应的值。我们将把handleChange()作为输入的onChange运行,最后导出Form组件。...拉取API数据 React的一种非常常见的用法是从API提取数据。

    13.1K20

    2020 年你应该知道的 React 库

    当我从 Angular 切换到 React,我绝对经历了它作为 React 的优势。 只有通过 React,您才能使用函数组件和 props 构建组件驱动的用户界面。...在您引入路由以前,您可以先尝试 React 的条件渲染,它虽然不是路由的合理替代,但是小型应用中以及足够用了。...建议: Formik React Hook Form React 中的数据获取库 很快,您就必须向远程 API 发出请求,以便在 React 中获取数据。...但是,有时候不仅需要提供复杂的异步请求,还需要它们具有更强大的功能,而且只是一个轻量级的库。我推荐的这些库之一称为 axios。当您的应用程序增大时,可以使用它来代替本地获取 API。...REACT VR/AR 实话说,我们很有可能用 React 深入虚拟现实或者增强现实中,我没有使用过这些库中的任何一个,但是它们是我在谈到 React AR/VR 时从大脑闪过的就是: React 360

    18.7K40

    React服务器组件入门

    然而,该网站的介绍中遗漏的是 Waku 支持 React 服务器组件——因此,如果你想自己试用它们,你不需要使用 Next.js(我对此表示感谢)。...值得一提的是,Waku 目前正在快速开发中,只应在非生产项目中使用。 React 服务器组件简介 所以我的看法是:RSC 使 React 开发人员能够在组件级别访问异步服务器端请求和结果数据。...你从未使用 GraphQL(一个普遍的误解)获取数据;相反,你正在查询它。...我从使用 Gatsby 的经验中知道,从组件中轻松访问数据是有好处的。...它可以真正帮助理解应用程序正在做什么,因为逻辑、数据和结果用户界面元素整齐地位于同一文件中,并且与追逐道具并尝试遵循数据旅程相比,开发人员体验通常更好。

    1K10

    请停止在 React 中使用“&&”进行条件渲染

    但是在使用React进行开发时,我们却不能正确使用&&,很容易导致UI错误。 因此,我们需要知道,&&运算符导致的React UI界面错误。 如何工作? 我们应该用什么代替&&? 1....&&运算符导致的React UI界面错误 我经常需要编写需要从服务器端获取数据的页面,这些数据用于呈现列表。如果数据的长度为0,则不应显示。...editors=1010 你会注意到,当 list 是一个空数组时,页面将呈现 0 而不是什么都没有。 我的天哪,这到底是怎么回事? 2.&& 是如何工作的? 这是一个 React 错误吗?...我们可以尝试这3种方式来避免这个问题。 3.1 使用!!list.length 我们可以把数组的长度转成布尔值,就不会再出现这个错误了。 // 1....往期推荐 不会这10个Web API,你还好意思说你是前端开发者? 互联网最值得加入的 173 家国企名单 前端加载超大图片(100M以上)实现秒开解决方案

    1.2K30

    Rust 不适合开发 Web API

    如果我正在编写一个地理编码器、一个路由引擎、一个实时消息平台、一个数据库或一个 CLI 工具,Rust 最合适。 但去年,我试图用 Rust 写一个传统网站的纯 API 服务,Rust 就不合适了。...Node.js 有 passport.js,Rails 有 devise,Django 有开箱即用的身份验证模型,在 Rust 中,你需要学习如何将共享 Vec 转换到底层加密库才能构建这个系统(译者注...但在我的情况下,甚至基本 API 功能都不完整,一个不复杂的系统——居然花了 10 多分钟来编译。Google 代码构建的硬件配置很差,每次都会超时,我啥都编译不了。...或者两次,第二次查询 ids 中的 user.id,一次获取所有作者,然后重新设置他们的照片属性。 N+1 查询通常优先使用数据库解决:比如将 N+1 查询改为单个查询,会带来明显的性能优化。...我们有很多方法来尝试和解决这些问题:你可以编写 SQL,并尝试使用 CTE 和 JOIN 在单个查询中完成大量工作,就像我们在 Observable 中所做的那样,或者使用像 ActiveRecord

    2.8K10

    React Hooks 还不如类?

    在 Funclass 示例中,你需要跟随这些 hooks 的踪迹,并尝试使用空的依赖项数组寻找 useEffect,以便了解组件在挂载时正在做什么。...膨胀的 API 在类旁边添加 hooks API 后,React 的 API 实际上增加了一倍。现在每个人都需要学习两种完全不同的方法。我必须说,新 API 比旧 API 晦涩得多。...如果我正在寻找某种初始化逻辑,我将跳转(VS Code 中是 cmd+shift+o)到 componentDidMount。...几年前,当我从 Angular 1.5 切换到 React 时,我曾赞叹 React 的 API 是如此简单,文档也如此之薄。...可是在第一次、第二次以及之后无数次尝试 hooks 时,我发现自己被迫一次又一次地回到文档中寻找答案。 11. 重要说明 阅读了一些评论后,我发现许多人认为我是类的拥护者。好吧,但这并不是事实。

    1.1K10

    深入浅出React中的refs

    如果你曾经尝试弄清楚它们是如何工作的,你就会明白我们为什么想要这样做,另外,我们将学习如何在 React 中实现命令式 API!...使用 useRef 在 React 中访问 DOM假如我想实现一个注册表单,这个注册表单包含用户名和邮箱号,用户名和邮箱号应该是必填项,当用户没有填写这些信息时,我不想只是简单的给输入框添加红色边框,我希望实现一个带有动画的表单...如果我能在这里做类似 InputField.shake() 和 InputField.focus() 的事情就好了!说到焦点——为什么我的 Form 组件仍然必须使用 DOM API 来触发它?...Form 组件不应该关心我们正在使用哪个 DOM 元素,或者我们是否使用 DOM 元素或其他东西。这就是所谓的关注点分离。...现在,一个很酷的表单已经准备好了,带有不错的抖动效果,React refs 不再神秘,React 中的命令式 API 实际上就是一个东西。这有多酷?

    1.1K10

    2023 年,这 9 个项目助你成为前端高手

    下图是这个 App 最终的样子。 你将学到什么 在构建这个 App 时,你将使用相对较新的 Hooks API,这有助于提高你的 React 技能。...这个示例项目使用 React 组件、Hooks、一个外部 API,当然,还使用 CSS 进行样式化。...我个人也喜欢使用 Nuxt。你应该尝试一下它,因为它也将帮助你成为更好的 Vue 开发者。...10 总结 我在本文中展示了 9 个可以构建的项目,每个项目都关注一个 JavaScript 框架或库。 现在,选择权就在你的手中——你是否会通过使用以前从未使用过的框架来尝试一些新东西?...点击底部阅读原文访问 InfoQ 官网,获取更多精彩内容! 今日好文推荐 每个月在云上“狂烧”180万,Ruby On Rails 之父:我们要直接买硬件!

    4.2K20

    2016 JavaScript 技术栈展望

    好在这一现象正在退热,优胜劣汰,优秀的项目慢慢沉淀下来,开发方式也越来越清晰。有些开发者正在尝试使用基于上述技术的框架进行开发,也在一定程度上减少了学习成本。...除非你正在维护一个陈旧的项目或者用到的第三方库依赖了 jQuery,否则已经没有必要使用它了。 我喜欢让项目保持简洁,在代码中只使用 fetch 。...我建议使用 isomorphic-fetch 在各个浏览器和服务端保持功能的一致性。 当然也可以其他优秀的第三方库异步获取数据,但我觉得 fetch 已经够用了。...我不认为上述有一个完美的解决方案,但我对 API 有一个自己的认知: 可预测,遵循一致性协议 支持在一次查询中获取多个实体 支持更新操作 易于调试 易于使用 到目前为止,我还没有发现满足上述所有条件的解决方案...如果你正在使用 RESFful,建议参考 Swagger 来编写 API。

    2.6K40
    领券