React 与 Hooks 如何使用 TypeScript 书写类型? 本文写于 2020 年 9 月 20 日 函数组件与 TS 对于 Hooks 来说是不支持使用 class 组件的. 如何在函数组件中使用 TS 呢? 首先定然是函数的类型,我们需要告诉 TS,这个函数他是个 React 组件. 如果是 JavaScript,我们会这么写函数组件: import React from 'react'; const MyComponent = () => { return <h1>你好…
总目录 从C#到TypeScript - 类型 从C#到TypeScript - 高级类型 从C#到TypeScript - 变量 从C#到TypeScript - 接口 从C#到TypeScript - 类 从C#到TypeScript - 函数 从C#到TypeScript - 装饰器 从C#到TypeScript - Promise 从C#到TypeScript - async await C# vs TypeScript - 高级类型 上一篇讲了基础类型,基本上用基础类型足够开发了,不过…
C# vs TypeScript - 高级类型 上一篇讲了基础类型,基本上用基础类型足够开发了,不过如果要更高效的开发,还是要看下高级类型,这篇和C#共同点并不多,只是延用这个主题. 联合类型 可以从字面上进行理解:其实就是多个类型联合在一起,用|符号隔开.如: string | number, 表示希望这个类型既可以是string,又可以是number.联合类型的字段只能调用这些类型共同拥有的方法,除非类型推论系统自动判断出真正的类型. //这里sn就是一个联合类型的字段,由于类型推论推断出s…
在使用 Angular 做项目的时候,对 TypeScript 的类型判断不太熟练,为了方便查找,特意对 TypeScript 的类型判断做了简单梳理.文章只是 TS 官网的内容摘要,没有高深的知识,想要深入学习 TS 还要看官网文档. 基础类型 // 布尔值 let isDone: boolean = false; // 数字 let decLiteral: number = 6; let hexLiteral: number = 0xf00d; let binaryLiteral: numb…
使用 react 的 hooks 进行全局的状态管理 React 最新正式版已经支持了 Hooks API,先快速过一下新的 API 和大概的用法. // useState,简单粗暴,setState可以直接修改整个state const [state,setState] = useState(value); // useEffect,支持生命周期 useEffect(()=>{ // sub return ()=>{ // unsub } },[]); // useContext,和 Rea…
⒈TypeScript的类型 JavaScript语言的数据类型包括以下7种: 1.boolean(布尔),true || false 2.null,表明null值得特殊关键字,JavaScript是大小写敏感的,不要误写成Null或者NULL 3.undefined,变量未定义时的属性 4.number,表示数字,例如1.1.2等等 5.string,表示字符串,例如:“Hello World!” 6.symbol,一种数据类型(在ES6种新添加的类型),表示该实例唯一且不可改变. 7.obj…
TypeScript函数类型 TypeScript函数的参数 TypeScript函数的this与箭头函数 TypeScript函数重载 一.TypeScript函数类型 在上一篇博客中已经对声明TypeScript类型变量已经做了初步的解析,这里先回顾以下: //声明函数 function add1(x:number,y:number):number{ return x+y; } let add2 = function(x:number,y:number):number{ return x +…
什么是工具类型 用 JavaScript 编写中大型程序是离不开 lodash 工具的,而用 TypeScript 编程同样离不开工具类型的帮助,工具类型就是类型版的 lodash .简单的来说,就是把已有的类型经过类型转换构造一个新的类型.工具类型本身也是类型,得益于泛型的帮助,使其能够对类型进行抽象的处理.工具类型主要目的是简化类型编程的过程,提高生产力. 使用工具类型的好处 先来看看一个场景,体会下工具类型带来什么好处. // 一个用户接口 interface User { name: s…
how to create react custom hooks with arguments React Hooks & Custom Hooks // reusable custom hooks function useVar(type = `A`) { let var = `var${type}`; let setVar = `setVar${type}`; // re-declared bug const [var, setVar] = useState(0); useEffect(()…
React Hooks & react forwardref hooks & useReducer react how to call child component method in another child component left index list => right map right map back to default value, right child call left child methods ??? https://stackoverflow.co…
在大多数程序中,我们必须根据输入做出决策.TypeScript 也不例外,使用条件类型可以描述输入类型与输出类型之间的关系. 本文同步首发在个人博客中,欢迎订阅.交流. 用于条件判断时的 extends 当 extends 用于表示条件判断时,可以总结出以下规律 若位于 extends 两侧的类型相同,则 extends 在语义上可理解为 ===,可以参考如下例子: type result1 = 'a' extends 'abc' ? true : false // false type res…
⒈交叉类型(Intersection Types) 交叉类型是将多个类型合并为一个类型. 这让我们可以把现有的多种类型叠加到一起成为一种类型,它包含了所需的所有类型的特性. 例如, Person & Serializable & Loggable同时是 Person 和 Serializable 和 Loggable. 就是说这个类型的对象同时拥有了这三种类型的成员. 每当我们正确的使用交叉类型的时候,TypeScript可以帮我们合理地将两个不同类型叠加为新的类型,并包含了所需的所有类型…
1.布尔值__boolean 2.数字__number----除了支持十进制和十六进制字面量,Typescript还支持ECMAScript 2015中引入的二进制和八进制字面量. 3.字符串__string;使用双引号( ")或单引号(')表示字符串.使用模版字符串,它可以定义多行文本和内嵌表达式. 这种字符串是被反引号包围( `),并且以${ expr }形式嵌入表达式 4.数组__(1)在元素类型后面接上[] let list: number[] = [1, 2, 3];      (2)…
在 <从 JavaScript 到 TypeScript 系列> 文章我们已经学习了 TypeScript 相关的知识. TypeScript 的核心在于静态类型,我们在编写 TS 的时候会定义很多的类型,但是主流的库都是 JavaScript 编写的,并不支持类型系统.那么如何让这些第三方库也可以进行类型推导呢? 这篇文章我们来讲解 JavaScript 和 TypeScript 的静态类型交叉口 -- 类型定义文件. 这篇文章首发于我的个人博客 <听说>. 前端开发 QQ 群:…
最近做的TS分享,到了高级类型这一块.通过琢磨和实验还是挖掘出了一些深层的东西,在此处做一下记录,也分享给各位热爱前端的小伙伴.   其实在学习TS之前就要明确以下几点:   1. typescript 是javascript的超集,这点是官方文档最先说明的,但是具体怎么理解就千差万别了.其实通俗的来说,ts语法就是基于js的一种通用规范,也就是js语法糖.   2. typescript是基于js的一门强类型的高级语言,而ts的所有新增语法都只是在编译环境有效,都只是在编译环境做的类型或语法的…
TypeScript(TS)是微软研发的编程语言,是JavaScript的超集,也就是在JavaScript的基础上添加了一些特性.其中之一就是类型声明. 一.基础类型 TS的基础类型有 Boolean,Number,String,Array,Tuple,Enum,Any,Void,Null,Undefined,Never,Object. ==布尔类型 Boolean== let isDone: boolean = false *在变量名后用冒号:T(T 代表TS的类型)声明变量的类型. ==数…
react hooks文档 λ yarn add react@16.7.0-alpha.2 λ yarn add react-dom@16.7.0-alpha.2 设置 state import React, { useState } from "react"; const l = console.log; function Test() { const [n, setN] = useState(0); const [info, setInfo] = useState({ name:…
枚举部分 Enumeration part 使用枚举我们可以定义一些有名字的数字常量. 枚举通过 enum关键字来定义. Using enumerations, we can define some numeric constants with names. Enumeration is defined by the enum keyword. enum Direction { Up = 1, Down, Left, Right } 枚举是在运行时真正存在的一个对象,其中一个原因是因为这样可以从…
布尔值 Boolean let isDone:boolean=false; 数字 Number let decLiteral:number=6; let hexLiteral:number=0xf00d; 字符串 String let name:string="bob"; name="smith"; 模版字符串 template let name:string=`Gene`; let age:number=37; let sentence:string=`Hello…
https://m.runoob.com/manual/gitbook/TypeScript/_book/doc/handbook/Type%20Inference.html 类型推导:发生在初始化变量和成员,设置默认参数值和决定函数返回值时. 最佳通用类型 计算通用类型算法会考虑所有的候选类型,并给出一个兼容所有候选类型的类型. 由于最终的通用类型取自候选类型,有些时候候选类型共享相同的通用类型,但是却没有一个类型能做为所有候选类型的类型.例如: let zoo = [new Rhino(),…
typescript支持定义类型加入推导式后产生新的类型 属性不变 但会改变对象的使用方式 这个是类型Person中加入ReadOnly推导出的新类型 他的属性全部是只读的 这个是推导出部分属性 这是一个子集 只要包含Person中的一个属性或多个属性就被认为是Partial<Person>类型…
1.boolean 布尔值 true/false let isDone: boolean = false; 2.number 数字:和JavaScript 一样,TypeScript 里的所有数字都是浮点数.另外支持二进制,八进制,十进制,十六进制. ; let hexLiteral: number = 0xf00d; let binaryLiteral: number = 0b1010; let octalLiteral: number = 0o744; 3.string 字符串:跟JavaS…
unknown 字面理解和 any 其实没差,任何类型都可赋值给它,但有一点, Anything is assignable to unknown, but unknown isn't assignable to anything but itself and any without a type assertion or a control flow based narrowing --TypeScript 3.0 Release notes - New unknown top type un…
useState react对useState进行了封装,调用了mountState. function useState<S>( initialState: (() => S) | S, ): [S, Dispatch<BasicStateAction<S>>] { currentHookNameInDev = 'useState'; mountHookTypesDev(); const prevDispatcher = ReactCurrentDispatch…
/* typeScript中的接口 - 1.属性类接口 */ /* 接口的作用:在面向对象的编程中,接口是一种规范的定义,它定义了行为和动作的规范,在程序设计里面,接口起到一种限制和规范的作用.接口定义了某一批类所需要遵守的规范,接口不关心这些类的内部状态数据,也不关心这些类里方法的实现细节,它只规定这批类里必须提供某些方法,提供这些方法的类就可以满足实际需要. typescrip中的接口类似于java,同时还增加了更灵活的接口类型,包括属性.函数.可索引和类等. 定义标准. */ // 1.属…
传统的JavaScript程序使用函数和基于原型的继承来创建可重用的组件,但对于熟悉使用面向对象方式的程序员来讲就有些棘手,因为他们用的是基于类的继承并且对象是由类构建出来的. 从ECMAScript 2015,也就是ECMAScript 6开始,JavaScript程序员将能够使用基于类的面向对象的方式. 而使用TypeScript,我们允许开发者现在就使用这些特性,并且编译后的JavaScript可以在所有主流浏览器和平台上运行,而不需要等到下个JavaScript版本. 下面看一个使用类的…
在代码的实现或者调用上能设定一定的限制和规范,就像契约一样.通常,我们把这种契约称为接口. TypeScript的核心原则之一是对值所具有的结构进行类型检查. 有时称为“鸭式辨型法”或“结构性子类型化”. 在TypeScript里,接口的作用就是为这些类型命名,以及为你的代码或第三方代码定义契约. 接口涉及到interface关键字.interface不仅可用于描述对象的结构,还可用做接口的关键字.接口是用于隔离类或模块的实现. interface是TypeScript完全独有的高级数据类型,用…
自ECMAScript 2015(ES6)起,symbol成为了一种新的原生类型,就像基本类型number和string一样. ⒈介绍及使用方式 TypeScript中使用symbol类型和JavaScript的使用方式如出一辙,也是通过Symbol构造函数创建的. let sym1 = Symbol(); let sym2 = Symbol("key"); // 可选的字符串key 需要注意的是,Symbols是不可改变且唯一的. let sym2 = Symbol("ke…
类型断言是个好用的玩意,虽然typescript很强大,但是有时还不如我们知道一个值的类型,导致在开发过程中总是报一些令人头痛的类型错误.使用断言,简单来说就是先做好一个假设,使得编译通过. 我一开始接触类型断言时是有点不明白的,后来我了解到原因是 “类型断言更像是类型的选择,而不是类型转换”.我发现不少博客文章里把类型断言说成了类型转换,这在最开始给我带来了一些困扰. 使用类型断言有两种方式: <类型>值 或者 值 as 类型 推荐以 as 方式,因为 jsx 这样的语法中只支持 as 方式…
一.react-hooks概念 React中一切皆为组件,React中组件分为类组件和函数组件,在React中如果需要记录一个组件的状态的时候,那么这个组件必须是类组件.那么能否让函数组件拥有类组件的功能?这个时候我们就需要使用hooks. Hooks让我们的函数组件拥有了类似类组件的特性,Hook是React16.8中新增的功能,它们允许您在不编写类的情况下使用状态和其他React功能 二.为什么React中需要类组件 1.需要记录当前组件的状态 2.需要使用组件的一些生命周期函数 三.类组件…