


Comment le type statique javascript analyse-t-il l'utilisation du flux (détails)
Le contenu de cet article explique comment analyser l'utilisation du flux des types statiques JavaScript (détails). Il a une certaine valeur de référence. Les amis dans le besoin peuvent s'y référer.
Cause
Après avoir recherché Baidu et Google, je n'ai pas trouvé la documentation chinoise de Flow. Ceci est évidemment hostile au pays. Bien que Flow ne soit généralement pas utilisé, les frameworks généraux l'utiliseront. pour la commodité des utilisateurs. Le framework peut être utilisé avec précision et de nombreux BUG mystérieux peuvent être évités. Comme cela n'existe pas, je prévois de traduire d'abord la partie des annotations de type et d'en installer beaucoup. >
annotation de type de fluxLorsque votre type n'est pas annoté, le flux ne fonctionnera pas, voyons donc comment le type de flux peut être annoté Ce n'est pas // cette annotationtype original. javascript a un total de 6 types de données primitifs.- Booléens
- Chaînes
- Numéros
- null
- non défini (vide dans les types de flux)
- Symboles (nouveau dans ECMAScript 2015, pas encore pris en charge dans Flow) le flux ne prend pas en charge les symboles
Par exemple, comme indiqué ci-dessous, vous ne pouvez transmettre que des .booleans littéraux, sauf que
1 2 3 4 5 6 |
|
1 2 3 4 5 6 7 8 |
|
1 2 3 4 5 6 7 8 9 10 |
|
1 2 3 4 5 6 7 |
|
1 2 |
|
1 2 3 4 5 |
|
1 2 3 4 |
|
1 2 3 4 5 6 7 8 9 10 11 12 |
|
1 2 3 4 5 6 7 8 9 |
|
1 2 3 4 5 6 7 8 9 |
|
Cette valeur peut être indéfinie mais elle ne peut pas être nulle
Options pour les paramètres de la fonction
Ajouter un point d'interrogation pour indiquer que les paramètres de cette fonction sont facultatifs
1 2 3 4 5 6 7 8 9 |
|
Paramètres par défaut de la fonction
Nouvelles fonctionnalités d'es5
1 2 3 4 5 6 7 8 9 |
|
symbole
le flux ne prend pas en charge le
type littéral
le flux peut non seulement spécifier le type, il peut également spécifier une valeur spécifique Très cool
comme :
1 2 3 4 5 6 7 8 9 10 |
|
comme :
1 2 3 4 5 6 7 8 9 10 11 12 |
|
Types mixtes (types mixtes)
Vous pouvez faire correspondre plusieurs types
1 2 3 |
|
Vous pouvez indiquer un type comme les génériques de Java (avec des différences), comme le montre l'exemple suivant, le le type renvoyé par la fonction est le même que le type passé dans la fonction.
1 2 3 |
|
Vous pouvez marquer une fonction comme celle-ci pour accepter tout type de paramètres
1 2 3 |
|
Lorsque vous utilisez mixte , bien que vous puissiez transmettre n'importe quel type, vous devez savoir de quel type il s'agit lorsque vous le renvoyez, sinon une erreur sera signalée
1 2 3 4 5 6 7 |
|
Tout type (n'importe quel type)
Don Ne confondez pas n'importe lequel et mixte, si vous souhaitez ignorer la vérification de type, alors vous pouvez utiliser n'importe lequel
1 2 3 4 5 6 7 8 |
|
Tant qu'il y a deux situations, vous pouvez utiliser n'importe lequel
-
L'ancien code a ajouté la vérification du type de flux, et l'utilisation d'autres types provoquera de nombreuses erreurs
Lorsque vous savez clairement que votre code ne peut pas réussir la vérification de type,
Évitez toute fuite
Lorsque vous déclarez l'un des paramètres transmis, les paramètres que vous renvoyez sont également tous. Pour éviter cette situation, vous devez le couper
1 2 3 4 5 6 7 8 9 |
|
- var - déclarer une variable, affectation sélective
- let - déclarer une variable de niveau bloc, auxiliaire facultatif
- const - déclarer Une variable au niveau du bloc se voit attribuer une valeur et ne peut pas être réaffectée
1 2 3 |
|
sont les mêmes que ci-dessus, ces deux types peuvent également être injectés automatiquementMais si vous injectez le type automatiquement, vous n'obtiendrez pas d'erreur lorsque vous réaffecterez le type modifiéSi déclarations, fonctions et autres conditions Le code peut indiquer avec précision de quel type il s'agit, vous pouvez donc éviter les contrôles de flux ou bien signaler des erreurs
1 2 3 4 5 6 7 8 9 10 11 12 |
|
1 2 3 4 5 6 7 8 |
|
1 |
|
1 2 3 |
|
1 2 3 4 5 6 7 8 9 10 |
|
1 2 3 |
|
1 2 3 |
|
<.>
Mais dans le cas suivant, le flux signalera une erreur1 2 3 4 5 6 7 |
|
1 2 3 4 5 6 7 8 9 10 11 |
|
1 2 3 4 5 6 7 8 9 10 |
|
如果你想跳过 flow 的 类型检查 , 除了用any 再函数上你还可以用 Function 不过这是不稳定的,你应该避免使用他
1 2 3 4 5 6 7 8 9 |
|
对象类型
对象类型语法
1 2 3 4 5 6 7 8 9 10 11 |
|
可选的对象属性
使用了flow, 对象不能访问不存再的属性, 以前是返回undefined 现在访问报错,如果想知道 访问并且赋值 会不会报错,(我建议你自己试一下)
你可以使用 ? 号来标明 这个属性 是可选的,可以为undefined
1 2 3 4 5 6 |
|
标明了类型的属性, 他们可以是undefined(属性赋值为undefined) 或者 空着不写(空对象,), 但是他们不可以是null
密封对象 (seald objects)
密封对象的概念不懂的 可以去了解一下, 就是这个对象不可以修改,但是引用的对象还是可以修改的; 在flow中 这种对象知道所有你声明的属性的值的类型
1 2 3 4 5 6 7 8 9 10 11 12 |
|
而且flow 不允许你往这种对象上面添加新的属性, 不然报错
非密封对象属性的重新赋值
注意了,flow 是静态类型检测工具 并不是动态的, 所以他不能在运行时判断你的变量是什么类型的, 所以他只能判断你这个对象是否是你赋值过的类型之一.
1 2 3 4 5 6 7 8 9 10 11 |
|
普通对象的非确定属性的类型是不安全的
1 2 3 4 5 6 7 8 |
|
额外对象类型 (extra object type)
在一个期望正常对象类型的地方,传一个有着额外属性的对象是安全的
1 2 3 4 5 6 7 8 9 |
|
flow 也支持精确的对象类型, 就是对象不能具有额外的属性;
1 2 |
|
如果你想结合精确对象, 需要用到 type 关键字, 我也不知道这个算不算操作符,应该是flow 底层编译支持的, 原声js 并没有这个东西
1 2 3 4 5 6 7 8 9 10 |
|
对象的maps (objects as maps)
虽然有了maps 这个数据结构 但是把对象当作maps 使用 依然很常见
1 2 3 4 5 |
|
索引也是一个可选的名字
1 2 3 4 5 6 |
|
索引可以和命名属性混合
1 2 3 4 5 6 7 8 9 10 11 12 |
|
对象类型(Object Type)
有时候你想创任意的对象, 那么你就可以传一个空对象,或者一个Object 但是后者是不安全的, 建议避免使用
数组类型
1 2 3 4 |
|
简写
1 2 3 4 |
|
?number[] === ?Array
数组的访问时不安全的
1 2 3 |
|
你可以通过下面这样的做法来避免, flow 并未修复这个问题, 所以需要开发者自己注意
1 2 3 4 5 6 |
|
$ReadOnlyArray
这个可以标记一个只能读 不能写的数组
1 2 |
|
但是引用类型还是可以写的
1 2 3 4 |
|
tuple types
这是一种新的类型, 是一种短的列表,但是时又限制的集合,在 javascript 中这个用数组来声明
1 2 3 4 |
|
可以把取出的值 赋值给具有一样类型的变量, 如果index 超出了索引范围,那么就会返回undefined 在 flow 中也就是 void
1 2 3 4 5 6 |
|
如果flow 不知道你要访问的时是那么类型, 那么他忽返回所有可能的类型,
1 2 3 4 5 6 7 |
|
tuple类型的长度一定要严格等于你声明时候的长度
tuple 不能匹配 数组类型, 这也是他们的差别
tuple 只能用 array 的 join() 方法 其他的都不可以用,否则报错
class type
javascript 的class 再flow 可以是值 也可以是类型
1 2 3 4 5 |
|
class 里的字段一定要声明类型了才可以用
1 2 3 4 5 6 7 |
|
再外部使用的字段,必须要再class 的块里面声明一次
1 2 3 4 5 6 7 8 9 10 11 12 |
|
声明并且赋值的语法
1 2 3 |
|
类的泛型
1 2 3 4 5 6 |
|
如果你要把class作为一个类型,你声明了几个泛型, 你就要传几个参数
1 2 3 4 5 6 7 8 |
|
别名类型(type aliases)
跟上面提到的 type 关键字一样
1 2 3 4 5 6 |
|
这个是类型别名 可以在不同的地方复用
1 2 3 4 5 6 7 8 |
|
别名泛型
1 2 3 4 |
|
别名泛型是参数化的,也就是你用了以后, 你声明的所有参数 你全部都要传
1 2 3 4 5 6 7 8 9 10 11 12 |
|
不透明的类型别名(opaque type aliases)
通过类型系统的加强抽象
不透明类型别名是不允许访问定义在文件之外的的基础类型的类型别名.
1 |
|
不透明类型别名可以复用
1 2 3 4 5 6 7 8 |
|
你可以可选的加一个子类型约束
在一个 不透明的类型别名
的类型后面
1 |
|
任何类型都可以作为父类型 或者 不透明的类型别名
的类型
1 2 3 4 5 6 7 8 |
|
不透明别名类型 的类型检查
在文件内部
在文件内部跟正常的类型别名一样
1 2 3 4 5 6 7 8 9 10 |
|
在文件外部
当你inport 一个 不透明的类型别是时候,他会隐藏基础类型
exports.js
1 |
|
imports.js
1 2 3 4 5 6 7 |
|
子类型约束(subTyping Constraints)
当你添加一个子 类型约束在一个不透明的类型别名上时, 我们允许不透明类型在被定义文件的外部被用作父类型
exports.js
1 |
|
imports.js
1 2 3 4 5 6 7 8 9 |
|
当你创建一个拥有子类型约束的 不透明类型别名, 这个类型在类型中的位置一定要是这个类型的子类型在父类中的位置 (这里的概念应该是跟泛型的概念差不多, 不相关的类型不可以强制转换)
1 2 3 |
|
泛型
不透明类型别名 有他们自己的泛型, 但是他们跟正常的泛型是差不多的
1 2 3 4 5 6 7 8 9 10 11 12 |
|
接口类型 (interface Types)
接口可以使一些拥有相同方法的类归为一类
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 |
|
如果你怕出错, 你可以手动的 使用 implements 告诉flow 哪些类实现了哪些接口,这可以预防你修改class 的时候出现错误
1 2 3 4 5 6 7 8 9 10 11 12 13 |
|
不要忘记了接口可以同时实现多个
接口的属性也是可以可选的
1 2 3 |
|
接口跟maps 联合
1 2 3 |
|
接口泛型
1 2 3 4 |
|
规矩还在,泛型你用了几个 ,你使用的时候 就要传递几个参数
1 2 3 4 5 6 7 8 9 10 11 12 |
|
接口属性的 只读,与只写
接口属性默认是不可变
的, 但是你可以添加修饰符让他们变成 covariant
只读或者Contravariance
只写;(关于不可变想了解的请看这里)
1 2 3 4 |
|
混合只读
1 2 3 |
|
允许指定多个类型
1 2 3 4 5 6 7 |
|
协变(covariant) 属性 通常是只读的,他比正常的属性更有用
1 2 3 4 5 6 7 8 9 10 11 12 13 14 |
|
contravariant
逆变 只写属性 允许你传递更少的类型
1 2 3 4 5 6 7 8 9 |
|
通常比正常的属性更有用
1 2 3 4 5 6 7 8 9 10 11 12 13 |
|
联盟类型 (union types)
类型的值可能是很多类型之一
使用 | 分开
1 |
|
可以竖直写
1 2 3 4 5 |
|
联盟类型可以组合
1 2 3 4 |
|
联盟类型请求一个,但是所有的都要处理
当你调用一个要接受联盟类型的函数的时候,你一定要传入一个在联盟类型中的类型,但是在函数里面你要处理所有的类型.
1 2 3 4 5 6 7 8 9 10 |
|
联盟改进
这里是上面演示的说明,可以使用 typeof 关键字来应对逐一的类型
1 2 3 4 5 6 7 |
|
脱节联盟 (disjoint Unions)
概念就不说了,难懂来看一下例子
想象我们有一个处理发送了请求之后响应的函数,当请求成功你那个的时候,我们得到一个对象,这个对象有 一个 success 属性 值为true 还有一个值我们需要更新的值, value
1 |
|
当请求失败的时候,我们得到一个对象这个对象有一个 success 属性 值为false,和一个 error 属性,定义了一个错误.
1 |
|
我们可以尝试用一个对象去描述这两个对象, 然而我们很快就发生了一个问题, 就是我们知道一个属性的存在与否(value 或者 error ) 取决于success(因为success为 true 那么 value才会存在) 但是 Flow 不知道.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 |
|
取而代之,如果我们创建一个两个对象类型的联盟类型,Flow 会知道基于success 属性 我们会使用哪个对象
1 2 3 4 5 6 7 8 9 10 11 12 13 |
|
脱节联盟与精确类型仪器使用
脱节连门要求你使用单一的属性去区分每个对象类型,你不能用两个不同的属性,去区分两个不同的类型
1 2 3 4 5 6 7 8 9 10 11 |
|
然而 你可以用精确对象类型
1 2 3 4 5 6 7 8 9 10 11 12 13 14 |
|
交叉类型(intersection types)
所有不同类型的类型值
1 2 3 4 5 6 7 8 9 10 11 12 13 14 |
|
可以把上面的连门类型理解为或 把交叉类型理解为& 语法都是一样的
1 2 3 4 5 6 7 8 9 |
|
我们在函数中和联盟函数相反, 我们不如传入所有的类型,但是在函数里面我们只需要做处理一种情况就OK
1 2 3 4 5 6 7 8 9 10 |
|
不可能的交叉类型
你总不能一个值 是数字的同时又是字符串吧
1 2 3 4 5 6 7 8 9 10 11 |
|
交叉对象类型
当你创建一个交叉对象类型时,你是在合并了他们所有的属性在一个对象上
1 2 3 4 5 6 7 8 9 10 |
|
如果声明的属性类型相同, 就相当于你声明了一个 交叉类型的属性
typeof Types (这个不好翻译 因为 typeof 是js中的一个关键字,在此我就不翻译这个了)
js有一个typeof 关键字,他会返回一个字符串说明
然而他是有限制的,typeof 对象 数组 null 都是 object
所以在flow中, 他把这个关键字重载了
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 |
|
你可以typeof 任何值
1 2 3 4 5 6 |
|
引用类型的 typeof 继承行为
你可以用typeof 的返回值作为一个类型
但是如果你typeof 一个指定了字面量类型的 变量, 那么那个类型就是字面量的值了
1 2 3 4 5 6 7 8 9 10 11 12 13 |
|
其他类型的 typeof 继承行为
1 2 3 4 5 6 7 8 9 10 11 12 13 |
|
镶嵌表达式类型(type casting expression)
把一个值镶嵌到不同的类型
有时不使用函数和变量去声明一个类型是很有用的,所以flow 支持多种方式去干这个事情(声明一个类型)
语法
1 |
|
这个表达式可以出现在表达式能出现的任何地方
1 2 3 |
|
也可以这样写
1 |
|
类型断言
1 2 3 4 5 6 |
|
类型嵌入
这个表达式是由返回值的,如果你接收了这个返回值,你会得到一个新的类型
1 2 3 4 5 6 7 8 9 10 11 |
|
通过 any 去转换类型
1 2 3 4 5 6 7 8 9 10 11 12 |
|
但是合适不安全且不推荐的,但是有时候他很有用
通过类型断言来进行类型检查
若是你想检查一个对象的类型,你不能直接 typeof 你得先用 断言表达式去转换然后再用typeof 去检查
想这样:
1 2 3 4 5 6 7 8 9 10 11 |
|
1 2 3 4 5 6 7 8 9 10 11 12 |
|
工具类型
flow 提供了一系列的 工具类型, 以便于再一些常见场景使用
详情看这里
模块类型
上面由类似的, 就是一个export 一个 import
注释类型
感觉没多大用处, 可以做一些标记,这个可以在不通过flow 编译的情况下直接使用在js文件上
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 |
|
看完能看懂所有flow 代码了吧...
相关推荐:
Flow之一个新的Javascript静态类型检查器_javascript技巧
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Outils d'IA chauds

Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

AI Hentai Generator
Générez AI Hentai gratuitement.

Article chaud

Outils chauds

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Comment utiliser WebSocket et JavaScript pour mettre en œuvre un système de reconnaissance vocale en ligne Introduction : Avec le développement continu de la technologie, la technologie de reconnaissance vocale est devenue une partie importante du domaine de l'intelligence artificielle. Le système de reconnaissance vocale en ligne basé sur WebSocket et JavaScript présente les caractéristiques d'une faible latence, d'un temps réel et d'une multiplateforme, et est devenu une solution largement utilisée. Cet article explique comment utiliser WebSocket et JavaScript pour implémenter un système de reconnaissance vocale en ligne.

WebSocket et JavaScript : technologies clés pour réaliser des systèmes de surveillance en temps réel Introduction : Avec le développement rapide de la technologie Internet, les systèmes de surveillance en temps réel ont été largement utilisés dans divers domaines. L'une des technologies clés pour réaliser une surveillance en temps réel est la combinaison de WebSocket et de JavaScript. Cet article présentera l'application de WebSocket et JavaScript dans les systèmes de surveillance en temps réel, donnera des exemples de code et expliquera leurs principes de mise en œuvre en détail. 1. Technologie WebSocket

Introduction à l'utilisation de JavaScript et de WebSocket pour mettre en œuvre un système de commande en ligne en temps réel : avec la popularité d'Internet et les progrès de la technologie, de plus en plus de restaurants ont commencé à proposer des services de commande en ligne. Afin de mettre en œuvre un système de commande en ligne en temps réel, nous pouvons utiliser les technologies JavaScript et WebSocket. WebSocket est un protocole de communication full-duplex basé sur le protocole TCP, qui peut réaliser une communication bidirectionnelle en temps réel entre le client et le serveur. Dans le système de commande en ligne en temps réel, lorsque l'utilisateur sélectionne des plats et passe une commande

Comment utiliser WebSocket et JavaScript pour mettre en œuvre un système de réservation en ligne. À l'ère numérique d'aujourd'hui, de plus en plus d'entreprises et de services doivent fournir des fonctions de réservation en ligne. Il est crucial de mettre en place un système de réservation en ligne efficace et en temps réel. Cet article explique comment utiliser WebSocket et JavaScript pour implémenter un système de réservation en ligne et fournit des exemples de code spécifiques. 1. Qu'est-ce que WebSocket ? WebSocket est une méthode full-duplex sur une seule connexion TCP.

JavaScript et WebSocket : Construire un système efficace de prévisions météorologiques en temps réel Introduction : Aujourd'hui, la précision des prévisions météorologiques revêt une grande importance pour la vie quotidienne et la prise de décision. À mesure que la technologie évolue, nous pouvons fournir des prévisions météorologiques plus précises et plus fiables en obtenant des données météorologiques en temps réel. Dans cet article, nous apprendrons comment utiliser la technologie JavaScript et WebSocket pour créer un système efficace de prévisions météorologiques en temps réel. Cet article démontrera le processus de mise en œuvre à travers des exemples de code spécifiques. Nous

Utilisation : En JavaScript, la méthode insertBefore() est utilisée pour insérer un nouveau nœud dans l'arborescence DOM. Cette méthode nécessite deux paramètres : le nouveau nœud à insérer et le nœud de référence (c'est-à-dire le nœud où le nouveau nœud sera inséré).

Tutoriel JavaScript : Comment obtenir le code d'état HTTP, des exemples de code spécifiques sont requis Préface : Dans le développement Web, l'interaction des données avec le serveur est souvent impliquée. Lors de la communication avec le serveur, nous devons souvent obtenir le code d'état HTTP renvoyé pour déterminer si l'opération a réussi et effectuer le traitement correspondant en fonction de différents codes d'état. Cet article vous apprendra comment utiliser JavaScript pour obtenir des codes d'état HTTP et fournira quelques exemples de codes pratiques. Utilisation de XMLHttpRequest

JavaScript est un langage de programmation largement utilisé dans le développement Web, tandis que WebSocket est un protocole réseau utilisé pour la communication en temps réel. En combinant les puissantes fonctions des deux, nous pouvons créer un système efficace de traitement d’images en temps réel. Cet article présentera comment implémenter ce système à l'aide de JavaScript et WebSocket, et fournira des exemples de code spécifiques. Tout d’abord, nous devons clarifier les exigences et les objectifs du système de traitement d’images en temps réel. Supposons que nous disposions d'un appareil photo capable de collecter des données d'image en temps réel.
