JS 中的常量以及柏拉图和亚里士多德与它有什么关系

js 中的常量以及柏拉图和亚里士多德与它有什么关系

在我看来,后辈将代码组件视为物质的东西,而前辈则更多地处理理想的类别。
或者也许这取决于一个人的世界观而不是他们的专业水平?

有时在代码审查期间,我会遇到代码,其中开发人员使用常量table_width而不是常量car_width,因为这是他找到的第一个具有合适值的常量。

当开发人员根据常量的值而不是名称来选择常量时,这是一个常见问题。事实证明,开发人员不理解常量的主要用途。在他看来,常量只是为了重用和可读性。

让我们回想一下柏拉图和亚里士多德对此的说法。

他们有自己的常量,称为ship_of_theseus.
https://en.wikipedia.org/wiki/ship_of_theseus
它在希腊语中的命名可能不同,但我们会用拉丁语写它,因此将其翻译成英语。

const ship_of_theseus = {    name: "ship of theseus",    parts: ["mast", "hull", "sail"]};

此例中的常数ship_of_theseus象征着忒修斯之船的不变身份。它的值随着时间的推移而变化,代表着物质的变化。

// Day 1: Initial state of the shipconst SHIP_OF_THESEUS = {    name: "Ship of Theseus",    parts: ["mast", "hull", "sail"]};// Day 2: Developer changes one part of the shipconst SHIP_OF_THESEUS = {    name: "Ship of Theseus",    parts: ["new mast", "hull", "sail"]};// Day 3: Developer changes another part of the shipconst SHIP_OF_THESEUS = {    name: "Ship of Theseus",    parts: ["new mast", "new hull", "sail"]};// Day 4: Developer changes structure of the part of the shipconst SHIP_OF_THESEUS = {    name: "Ship of Theseus",    parts: {        mast: "new mast",        hull: "new hull",        sail: "sail"    }};

理想(常数):

ship_of_theseus:每一天,这个常数都代表着忒修斯之船的理想本质。尽管其价值发生了变化,但船舶的概念保持不变。

材料(常数值):

零件:每天都会变化的船舶零件列表。这反映了船舶的物质体现,随着时间的推移而变化。

柏拉图论理想与物质:

常数ship_of_theseus作为理想形式保持不变:每天它都代表忒修斯之船。然而,它的价值(零件)可能会发生变化,反映材料变化。

亚里士多德论形式与物质:

亚里士多德会说,船的身份是通过其 formfunction 保存的(与 js 中的鸭子类型非常相似,不是吗?)。在我们的示例中,尽管船舶的各个部分发生了变化,但对象的形式(其结构和功能)保持不变。尽管部件发生了变化,但每天它仍然是同一艘忒修斯之船。

那么使用常量的实际好处是什么?

主要好处不是可读性和可重用性。主要好处是将代码分离为理想材料(根据柏拉图)或形式物质(根据亚里士多德)。

通过这种分离,我们可以在不改变形式的情况下改变内容。
而且我们可以在整个程序中使用表单而不用担心任何问题。

以上就是JS 中的常量以及柏拉图和亚里士多德与它有什么关系的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1490143.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月19日 12:58:40
下一篇 2025年12月18日 10:53:37

相关推荐

  • 使用 Formity 在 React 中创建动态、多步骤表单

    构建现代 Web 应用程序时,表单通常成为用户体验的关键部分。无论是收集用户数据、提供多步骤向导还是构建交互式调查,创建动态和响应式表单的挑战很快就会变得难以承受。输入 Formity,这是一个 npm 包,它消除了在 React 中创建表单的痛苦。 什么是形式? Formity 是一个高级表单构建…

    2025年12月19日
    000
  • 开始使用 Vercel

    vercel 是一个流行的前端应用程序部署平台。它提供了一个命令行界面 (cli),允许您与 vercel 项目交互并高效部署应用程序。以下是一些常见的 vercel cli 命令及其用途: 安装 使用vercel cli之前,需要安装它。你可以使用 npm 来做到这一点: npm install …

    2025年12月19日
    000
  • JavaScript:默认参数、扩展运算符、剩余参数和解构!

    默认参数 我们可以直接在参数列表中添加默认值 function rolldie(numsides = 6) { return math.floor(math.random() * numsides) + 1;} 这里,需要注意秩序。默认参数只能出现在任何没有默认值的参数之后: function gr…

    2025年12月19日
    000
  • Let、Const 和 Var 概述:主要差异解释

    曾经有一段时间,我使用并理解了 javascript 中 let、const 和 var 的实际用法,但用语言解释它是具有挑战性的。如果您发现自己处于类似的困境,那么需要关注的关键点是范围、提升、重新初始化和重新分配方面的差异。 范围: 如果在任何函数外部声明,则 var 是函数作用域或全局作用域。…

    2025年12月19日
    000
  • 为您的项目选择正确方法的 API 架构终极指南

    在当今互联的数字环境中,api(应用程序编程接口)充当重要的连接器,使不同的软件系统能够无缝通信和共享数据。作为开发人员,选择正确的 api 架构可以决定项目的成败。让我们深入探讨 2024 年主导科技世界的 6 大 api 架构,探索它们的优势、用例以及它们如何提升您的下一个项目。 1. soap…

    2025年12月19日
    000
  • Vue js 通用编码标准

    以下是 vue.js 的其他好的和坏的做法: 通用编码标准 避免魔法数字和字符串:对重复使用或具有特殊含义的值使用常量。 // good const max_items = 10; function additem(item) { if (items.length < max_items) {…

    2025年12月19日
    000
  • 通天“^”,却被加载了“”

    节点 – v14错误:[BABEL] /codebuild/output/src3999571347/src/client/src/index.js:需要 Babel“^7.16.0”,但加载了“7.12.3”。如果您确定您有 @babel/core 的兼容版本,则构建过程中的某些内容可…

    2025年12月19日
    000
  • 面向对象编程 – 现实的抽象

    您好,在这篇看似教程的文章中,我们将讨论一个特别让我头疼的话题。然而,这种困难促使我不断学习、研究、研究,将日常生活的抽象化为自己的抽象,从而将代码变成有形事物的表示(相信我,这有时可能是一项艰巨的任务)。我对这个主题非常热情,现在我在这篇文章中分享了理解它的重要数据,所以让我们进入问题的核心。 我…

    2025年12月19日
    000
  • 如何使用 HMPL 减少客户端上的 javascript 文件大小?

    大家好!在这篇文章中,我想告诉你如何通过 hmpl 这样的模板语言来多次减小 javascript 文件的大小。 文章中出现的技术方法并不新鲜,但今天仍然足够流行,值得讨论。 减小 javascript 文件的大小将使页面在客户端上加载得更快。如果我们采用现代 spa,即使考虑到所有的缩小,文件大小…

    2025年12月19日
    000
  • 自动化云恢复挑战:使用 GitHub Actions 实施 CI/CD

    云简历挑战 – 第 2 部分 介绍 在本系列的第一部分中,我们逐步介绍了如何使用各种 aws 服务构建云原生简历网站。现在,我们将通过使用 github actions 实施持续集成和持续部署 (ci/cd),将我们的项目提升到一个新的水平。这种自动化对于有效维护和更新我们的云简历至关重…

    2025年12月19日
    000
  • 4 年内掌握 Tailwind CSS 与流行 JavaScript 框架的集成

    您准备好增强您的 web 开发工作流程了吗?别再犹豫了!在这份综合指南中,我们将引导您完成将 tailwind css 与四个最热门的 javascript 框架无缝集成的过程:react、angular、next.js 和 nuxt.js。无论您是经验丰富的专业人士还是刚刚起步,本教程都将帮助您立…

    2025年12月19日 好文分享
    000
  • JavaScript 中的二叉搜索树

    在 javascript 中实现二叉搜索树 在这篇文章中,我们将探索如何在 javascript 中实现基本的二叉搜索树 (bst)。我们将介绍插入节点和执行不同的树遍历方法 – 中序、前序和后序。 节点类首先,我们定义一个 node 类来表示树中的每个节点: class node { …

    2025年12月19日
    000
  • 如何在 React 中创建可访问的图表:包容性数据可视化指南

    什么是数据可视化中的可访问性 数据可视化是沟通的关键,但残疾人可能无法使用。数据可视化的可访问性对于确保所有用户(无论能力如何)都能理解图表并与图表交互至关重要。 highcharts 拥有创建可访问图表的工具和功能,依赖屏幕阅读器的用户将受益于正确的标签和注释。 选择正确的图表类型 不同的图表类型…

    2025年12月19日
    000
  • Arrayslice 与 Arraysplice:消除混淆

    介绍 作为一名 javascript 开发人员,我经常发现两个数组方法有点难以掌握/完全掌握 数组.切片 数组.splice。 因此,我决定深入研究并用清晰的示例来分解这些方法。 如果我重写语法 数组.切片 returns the deleted elements in a form of arra…

    2025年12月19日
    000
  • 使用 InversifyJS 在 Nodejs 中实现依赖注入

    嘿,开发者社区! 我刚刚在我的博客上发表了一篇关于如何使用 inversifyjs 在 node.js 中实现依赖注入的详细文章。如果您希望使 node.js 应用程序更加模块化、可维护和可测试,那么本指南适合您! 在本文中,我介绍: 什么是依赖注入以及为什么它很重要。如何在 node.js 项目中…

    2025年12月19日
    000
  • 使用 AWS Bedrock 将 GenAI 添加到 Angular 应用程序

    将人工智能集成到 web 应用程序中已经变得越来越普遍。 aws bedrock 提供了一个强大的平台来访问和利用基础模型 (fm) 来构建生成式 ai 应用程序。本文将指导您使用 aws bedrock 将 ai 功能集成到 angular 应用程序中。 先决条件 对 angular 和 type…

    2025年12月19日
    000
  • Vue 和 Tailwind 管理框架

    github |网站 添加了一些“必须”的功能,并将在此分享。 我们将非常感谢您在评论中提出的建议! 预制登录: 立即学习“前端免费学习笔记(深入)”; 用户管理: Chat-GPT 文本补全插件: 每个操作的审核日志(不包括密码哈希等敏感字段): TOTP 2FA 插件: S3上传插件: 开箱即用…

    2025年12月19日 好文分享
    000
  • 代码之旅:使用 Nextjs、Tailwind CSS 和 Framer Motion 打造我的开发者组合

    一个想法的起源在一个以快速技术发展为主导的世界中,作为一名 Web 开发人员要想脱颖而出,往往取决于一个关键的工件:产品组合。正是在这个数字复兴时期,我决定打造我的项目——不仅仅是作为项目的展示,也是我在现代网络技术方面的旅程和专业知识的证明。 第 1 章:选择我的同伴 — Next.js我的旅程始…

    2025年12月19日
    000
  • React 综合指南

    react 19 来了! ? 在本文中,我们将探索 react 19 中的新功能和改进。让我们开始吧! react 19 的新增功能 react 19 是 react 团队的最新主要版本,具有多项突破性功能和增强功能,旨在使开发过程更加高效,并使生成的应用程序更快、更强大。该版本继续建立在其前身奠定…

    2025年12月19日
    000
  • JavaScript 与 TypeScript 你应该选择哪一个?

    您是否在下一个 web 开发项目中在 javascript 和 typescript 之间左右为难?你不是一个人!当我们进入 2024 年时,这两种强大语言之间的争论比以往任何时候都更加激烈。无论您是经验丰富的开发人员还是刚刚开始编码之旅,这份综合指南都将帮助您做出明智的决定。让我们探讨一下 jav…

    2025年12月19日
    000

发表回复

登录后才能评论
关注微信