码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 【TypeScript】初探,行则将至


    官方文档

    从零开始学习一项新技术时,在你真的产生疑惑之前,官方文档是你离不开的朋友和工具,就像你新买的家电,无论你多么熟悉它,总要翻翻说明书。

    JavaScript中那些“熟知”且苦恼的场景

    拼写错误

    // 意外行为
    const obj = { width: 10, height: 15 };
    
    const area = obj.width * obj.heigth; // NaN
    
    • 1
    • 2
    • 3
    • 4

    隐式类型转换

    if ("" == 0) {
      // 他们相等!但是为什么呢??
    }
    if (1 < x < 3) {
      // x是 *任何* 值都为真!
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6

    大多数时候,我们都能很快的确认到问题,但十几个、几十个的before和after组合在一起,确实让人很苦恼。

    TypeScript: 静态类型检查器

    一些语言本身就不允许那些错误的程序运行。在不运行代码的情况下检测其中的错误称为 静态检查 。根据被操作的值的种类来确定是什么错误和什么不是错误,这称为静态 类型 检查。

    TypeScript 在执行之前,基于 值的类型 检查程序是否有错误。上一小节提到的意外行为,会被它提前检测出来

    const obj = { width: 10, height: 15 };
    const area = obj.width * obj.heigth;
    // 属性“heigth”在类型“{ width: number; height: number; }”上不存在。你是否指的是“height”?
    
    • 1
    • 2
    • 3

    JavaScript 的类型化超集

    TypeScript和JavaScript的关系:TypeScript 是 JavaScript 的超集 ,因此 JS 语法是合法的 TS。语法是指我们编写文本以组成程序的方式。

    TypeScript 不会将任何 JavaScript 代码视为错误。但是,TypeScript 是一个类型化的超集,意味着它添加了针对如何使用不同类型的值的规则。

    官方文档的例子非常的形象的体现了这点:

    console.log(4 / []); // Infinity
    
    • 1

    这句话执行起来不会报错,但是通常情况下它就是无意义的,TypeScript 在遇到这段代码后就会进行提醒,因为在大多数时候,这是编程错误。TypeScript 的类型检查器旨在允许正确的程序通过,同时仍然捕获尽可能多的常见错误。如果你将.js切换到.ts出现了一些莫名其妙的错误,也可能源于此。

    运行时行为

    TypeScript 保留了 JavaScript 的 运行时行为 。例如,在JavaScript 中被零除的结果是 Infinity,而不是抛出运行时异常。原则上,TypeScript 绝不 改变 JavaScript 代码的运行时行为。

    这意味着,如果将代码从 JavaScript 迁移到 TypeScript ,即使 TypeScript 认为代码有类型错误,也可以保证以相同的方式运行。

    参考链接:

    • 面向编程初学者的 TypeScript
    • 为 JavaScript 程序员准备的 TypeScript
    • 我是如何从零开始学TypeScript的
  • 相关阅读:
    3D建模游戏场景创建大致流程
    HTML+CSS+JavaScript仿京东购物网站制作 html静态网页设计制作 dw静态网页成品模板素材网页 web前端网页设计与制作 div静态网页设计
    1373. 二叉搜索子树的最大键值和
    机器人打磨抛光
    2.1 C++面向对象编程_访问控制和继承
    sed的不同执行方式
    【论文阅读笔记】PA-SAM: Prompt Adapter SAM for High-Quality Image Segmentation
    Maven中央仓库增加依赖漏洞提醒功能
    神经网络算法的关键参数,神经网络的参数有哪些
    Nuxt - 自定义页面布局,<Nuxt /> 个性化多套模板(一个项目内既要有用户正常浏览的普通页面,又要存在后台管理系统布局的页面)
  • 原文地址:https://blog.csdn.net/jbj6568839z/article/details/127873045
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号