当前位置:首页 > 文章列表 > 文章 > 前端 > JavaScript 的有趣之处以及 TypeScript 如何让它变得更好

JavaScript 的有趣之处以及 TypeScript 如何让它变得更好

来源:dev.to 2024-10-12 18:25:00 0浏览 收藏

IT行业相对于一般传统行业,发展更新速度更快,一旦停止了学习,很快就会被行业所淘汰。所以我们需要踏踏实实的不断学习,精进自己的技术,尤其是初学者。今天golang学习网给大家整理了《JavaScript 的有趣之处以及 TypeScript 如何让它变得更好》,聊聊,我们一起来看看吧!

JavaScript 的有趣之处以及 TypeScript 如何让它变得更好

javascript 是一种我们都喜欢的语言,对吧?它灵活、轻便,并且可以随处运行。但老实说,尽管它很伟大,但它可能很奇怪。那种奇怪的感觉会让你在看到一些不应该起作用的东西后质疑自己的理智。

在本文中,我们将探讨 javascript 中的一些怪癖 - 那些在您最意想不到的时候让您感到惊讶的行为。幸运的是,对于开发者来说,有一位身穿闪亮盔甲的骑士,叫做typescript。我们在这里向您展示如何通过使这些 javascript 的怪异更易于管理来避免您烦恼。


1. == vs === 大辩论

javascript 为我们提供了两种相等性:== 或松散相等和 === 或严格相等。

console.log(0 == '0'); // true
console.log(0 === '0'); // false

等等,什么?是的,javascript 使 0 和 '0' 在 == 时被视为相等,但在 === 时则不然。这是因为 == 在进行比较之前会进行 类型强制 或类型转换。它试图为您提供帮助,将该字符串转换为数字,但是这个帮助会导致错误。

想象一下在用户输入上使用 == 来检查数字。当类型不同导致难以追踪的意外行为时,您可能会得到正确的结果。为什么这很重要?因为 javascript 的强制类型通常会起作用,直到它破坏了一些重要的东西。

typescript 如何提供帮助

typescript 已经强制执行开箱即用的类型安全。如果你比较两个不同类型的东西,在你运行任何代码之前它就会对你大喊大叫:

let a: number = 0;
let b: string = '0';

console.log(a === b); // typescript error: this comparison is invalid

将数字与字符串进行比较时任何惊喜都消失了。 typescript 确保您始终比较苹果和苹果,或者在这种情况下进行数字与数字的比较。


2. 神秘的 undefined 与 null

undefined 和 null 都表示什么都没有,但方式略有不同。 undefined 是 javascript 分配给尚未初始化的变量的值,而 null 用于当您有意分配空值时。它们各不相同,但又相似得令人困惑。

let foo;
console.log(foo); // undefined

let bar = null;
console.log(bar); // null

除非你很小心,否则你可能最终会检查其中一个而不是另一个,这会导致一些令人困惑的错误。

if (foo == null) {
    console.log("this catches both undefined and null");
}

这可行,但如果您没有清楚地区分两者,可能会导致微妙的错误。

typescript 如何提供帮助

typescript 鼓励您明确而准确地判断某些内容是否可以为 null 或未定义。它通过让您显式处理这两种情况来实现这一点,这样您就可以确定发生了什么:

let foo: number | undefined;
let bar: number | null = null;

// typescript will enforce these constraints
foo = null; // error
bar = 5; // no problem!

使用 typescript,您可以决定允许哪些类型,这样就不会意外地混合类型。这种严格性可以保护您免受忘记检查 null 或未定义的错误的影响。


3. nan(非数字)的奇怪情况

你遇到过可怕的 nan 吗?它是 not-a-number, 的缩写,当您尝试执行没有意义的数学运算时,它会弹出。

console.log(0 / 0);  // nan
console.log("abc" - 5);  // nan

这里有一个问题:nan 实际上是数字类型。没错,不是数字是一个数字!

console.log(typeof nan); // "number"

如果您没有明确检查 nan,这可能会导致一些真正奇怪的结果。更糟糕的是,nan 永远不会等于它自己,所以你不能轻易地比较它来检查它是否存在。

console.log(nan === nan); // false

typescript 如何提供帮助

typescript 可以通过在编译时强制执行适当的类型检查和捕获错误操作来缓解此问题。如果 typescript 可以推断某个操作将返回 nan,那么它甚至可以在代码运行之前抛出错误。

let result: number = 0 / 0; // warning: possible 'nan'

typescript 还可以帮助您缩小 nan 可能出现的时间和位置,从而鼓励更好地处理数值。


4. 狂野这

javascript 中的 this 是最强大但最容易被误解的概念之一。这个值完全取决于如何调用函数,这可能会在某些上下文中导致意外的行为。

const person = {
    name: 'alice',
    greet() {
        console.log('hello, ' + this.name);
    }
};

settimeout(person.greet, 1000); // uh-oh, what happened here?

您可能期望在一秒钟后看到“hello, alice”打印出来,但相反,您会得到 hello, undefined。为什么?因为settimeout里面的this指的是全局对象,而不是person对象。

typescript 如何提供帮助

typescript 可以通过使用没有自己的 this 的箭头函数来帮助您避免此类问题,并保留它们所在对象的上下文。

const person = {
    name: 'alice',
    greet: () => {
        console.log('hello, ' + person.name); // always refers to 'person'
    }
};

settimeout(person.greet, 1000); // no more surprises!

这种行为不会再出乎意料了。 typescript 迫使您考虑上下文并帮助您正确绑定它,从而降低出现奇怪的未定义错误的风险。


5. 函数提升:当顺序不重要时

javascript 函数被提升到作用域的顶部;这意味着您甚至可以在代码中声明它们之前调用它们。这是一个很酷的技巧,但如果您不注意正在发生的事情,也可能会感到困惑。

greet();

function greet() {
    console.log('hello!');
}

虽然这很方便,但也可能引起混乱,尤其是当您尝试调试代码时。

由于函数声明提升,这工作得很好。但它可能会使您的代码更难理解,尤其是对于其他开发人员(或离开该项目几个月后的您自己)。

typescript 如何提供帮助

typescript 不会改变提升的工作方式,但它可以为您提供有关代码结构的更清晰的反馈。如果您在定义函数之前不小心调用了该函数,typescript 会立即通知您。

greet(); // Error: 'greet' is used before it’s defined

function greet() {
    console.log('Hello!');
}

typescript 会强制您进行一些清理工作,即在使用函数之前对其进行声明。这样可以让你的代码更易于维护。


总结一下

javascript 是一门令人惊叹的语言,但它有时确实很古怪。通过使用 typescript,您可以驯服 javascript 的一些最奇怪的行为,并使您的代码更安全、更可靠且更易于维护。无论您是使用 null 和 undefined、驯服它还是防止 nan 灾难,typescript 都可以为您提供工具来避免 javascript 的灵活(但有时不可预测)性质带来的麻烦。

所以下次当你发现自己对 javascript 的奇怪怪癖感到困惑时,请记住:typescript 可以为你提供帮助!

编码愉快!

今天关于《JavaScript 的有趣之处以及 TypeScript 如何让它变得更好》的内容就介绍到这里了,是不是学起来一目了然!想要了解更多关于的内容请关注golang学习网公众号!

版本声明
本文转载于:dev.to 如有侵犯,请联系study_golang@163.com删除
Java函数式编程中高阶函数与函数式组合的区别?Java函数式编程中高阶函数与函数式组合的区别?
上一篇
Java函数式编程中高阶函数与函数式组合的区别?
Implementing Long Press Functionality Using React Native Gesture Handler in React Native Application
下一篇
Implementing Long Press Functionality Using React Native Gesture Handler in React Native Application
查看更多
最新文章
查看更多
课程推荐
  • 前端进阶之JavaScript设计模式
    前端进阶之JavaScript设计模式
    设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
    542次学习
  • GO语言核心编程课程
    GO语言核心编程课程
    本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
    508次学习
  • 简单聊聊mysql8与网络通信
    简单聊聊mysql8与网络通信
    如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
    497次学习
  • JavaScript正则表达式基础与实战
    JavaScript正则表达式基础与实战
    在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
    487次学习
  • 从零制作响应式网站—Grid布局
    从零制作响应式网站—Grid布局
    本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
    484次学习
查看更多
AI推荐
  • 茅茅虫AIGC检测:精准识别AI生成内容,保障学术诚信
    茅茅虫AIGC检测
    茅茅虫AIGC检测,湖南茅茅虫科技有限公司倾力打造,运用NLP技术精准识别AI生成文本,提供论文、专著等学术文本的AIGC检测服务。支持多种格式,生成可视化报告,保障您的学术诚信和内容质量。
    93次使用
  • 赛林匹克平台:科技赛事聚合,赋能AI、算力、量子计算创新
    赛林匹克平台(Challympics)
    探索赛林匹克平台Challympics,一个聚焦人工智能、算力算法、量子计算等前沿技术的赛事聚合平台。连接产学研用,助力科技创新与产业升级。
    100次使用
  • SEO  笔格AIPPT:AI智能PPT制作,免费生成,高效演示
    笔格AIPPT
    SEO 笔格AIPPT是135编辑器推出的AI智能PPT制作平台,依托DeepSeek大模型,实现智能大纲生成、一键PPT生成、AI文字优化、图像生成等功能。免费试用,提升PPT制作效率,适用于商务演示、教育培训等多种场景。
    105次使用
  • 稿定PPT:在线AI演示设计,高效PPT制作工具
    稿定PPT
    告别PPT制作难题!稿定PPT提供海量模板、AI智能生成、在线协作,助您轻松制作专业演示文稿。职场办公、教育学习、企业服务全覆盖,降本增效,释放创意!
    99次使用
  • Suno苏诺中文版:AI音乐创作平台,人人都是音乐家
    Suno苏诺中文版
    探索Suno苏诺中文版,一款颠覆传统音乐创作的AI平台。无需专业技能,轻松创作个性化音乐。智能词曲生成、风格迁移、海量音效,释放您的音乐灵感!
    98次使用
微信登录更方便
  • 密码登录
  • 注册账号
登录即同意 用户协议隐私政策
返回登录
  • 重置密码