• <noscript id="ggggg"><dd id="ggggg"></dd></noscript>
    <small id="ggggg"></small> <sup id="ggggg"></sup>
    <noscript id="ggggg"><dd id="ggggg"></dd></noscript>
    <tfoot id="ggggg"></tfoot>
  • <nav id="ggggg"><cite id="ggggg"></cite></nav>
    <nav id="ggggg"></nav>
    成人黃色A片免费看三更小说,精品人妻av区波多野结衣,亚洲第一极品精品无码,欧美综合区自拍亚洲综合,久久99青青精品免费观看,中文字幕在线中字日韩 ,亚洲国产精品18久久久久久,黄色在线免费观看

    TypeScript 運行時類型檢查指南

    2020-7-10    seo達人

    為什么需要額外的類型檢查?

    TypeScript 只在編譯期執(zhí)行靜態(tài)類型檢查!實際運行的是從 TypeScript 編譯的 JavaScript,這些生成的 JavaScript 對類型一無所知。編譯期靜態(tài)類型檢查在代碼庫內(nèi)部能發(fā)揮很大作用,但對不合規(guī)范的輸入(比如,從 API 處接收的輸入)無能為力。


    運行時檢查的嚴格性

    至少需要和編譯期檢查一樣嚴格,否則就失去了編譯期檢查提供的保證。

    如有必要,可以比編譯期檢查更嚴格,例如,年齡需要大于等于 0。

    運行時類型檢查策略

    定制代碼手動檢查

    靈活

    可能比較枯燥,容易出錯

    容易和實際代碼脫節(jié)

    使用校驗庫手動檢查

    比如使用 joi:


    import Joi from "@hapi/joi"const schema = Joi.object({    firstName: Joi.string().required(),    lastName: Joi.string().required(),    age: Joi.number().integer().min(0).required()});

    靈活

    容易編寫

    容易和實際代碼脫節(jié)

    手動創(chuàng)建 JSON Schema

    例如:


    {  "$schema": "http://json-schema.org/draft-07/schema#",  "required": [    "firstName",    "lastName",    "age"  ],  "properties": {    "firstName": {      "type": "string"    },    "lastName": {      "type": "string"    },    "age": {      "type": "integer",      "minimum": 0    }  }}

    使用標準格式,有大量庫可以校驗。

    JSON 很容易存儲和復用。

    可能會很冗長,手寫 JSON Schema 可能會很枯燥。

    需要確保 Schema 和代碼同步更新。

    自動創(chuàng)建 JSON Schema

    基于 TypeScript 代碼生成 JSON Schema

    -- 比如 typescript-json-schema 這個工具就可以做到這一點(同時支持作為命令行工具使用和通過代碼調(diào)用)。

    -- 需要確保 Schema 和代碼同步更新。

    基于 JSON 輸入示例生成

    -- 沒有使用已經(jīng)在 TypeScript 代碼中定義的類型信息。

    -- 如果提供的 JSON 輸入示例和實際輸入不一致,可能導致錯誤。

    -- 仍然需要確保 Schema 和代碼同步更新。

    轉譯

    例如使用 ts-runtime。


    這種方式會將代碼轉譯成功能上等價但內(nèi)置運行時類型檢查的代碼。


    比如,下面的代碼:


    interface Person {    firstName: string;    lastName: string;    age: number;}const test: Person = {    firstName: "Foo",    lastName: "Bar",    age: 55}

    會被轉譯為:


    import t from "ts-runtime/lib";const Person = t.type(    "Person",    t.object(        t.property("firstName", t.string()),        t.property("lastName", t.string()),        t.property("age", t.number())    ));const test = t.ref(Person).assert({    firstName: "Foo",    lastName: "Bar",    age: 55});

    這一方式的缺陷是無法控制在何處進行運行時檢查(我們只需在輸入輸出的邊界處進行運行時類型檢查)。


    順便提一下,這是一個實驗性的庫,不建議在生產(chǎn)環(huán)境使用。


    運行時類型派生靜態(tài)類型

    比如使用 io-ts 這個庫。


    這一方式下,我們定義運行時類型,TypeScript 會根據(jù)我們定義的運行時類型推斷出靜態(tài)類型。


    運行時類型示例:


    import t from "io-ts";const PersonType = t.type({  firstName: t.string,  lastName: t.string,  age: t.refinement(t.number, n => n >= 0, 'Positive')})

    從中提取相應的靜態(tài)類型:


    interface Person extends t.TypeOf<typeof PersonType> {}

    以上類型等價于:


    interface Person {    firstName: string;    lastName: string;    age: number;}

    類型總是同步的。

    io-ts 很強大,比如支持遞歸類型。

    需要將類型定義為 io-ts 運行時類型,這在定義類時不適用:

    -- 有一種變通的辦法是使用 io-ts 定義一個接口,然后讓類實現(xiàn)這個接口。然而,這意味著每次給類增加屬性的時候都要更新 io-ts 類型。

    不容易復用接口(比如前后端之間使用同一接口),因為這些接口是 io-ts 類型而不是普通的 TypeScript 類型。

    基于裝飾器的類校驗

    比如使用 class-validator 這個庫。


    基于類屬性的裝飾器。

    和 Java 的 JSR-380 Bean Validation 2.0 (比如 Hibernate Validator 就實現(xiàn)了這一標準)很像。

    -- 此類 Java EE 風格的庫還有 typeorm (ORM 庫,類似 Java 的 JPA)和 routing-controllers (用于定義 API,類似 Java 的 JAX-RS)。

    代碼示例:


    import { plainToClass } from "class-transformer";import {     validate, IsString, IsInt, Min } from "class-validator";class Person {    @IsString()    firstName: string;    @IsString()    lastName: string;    @IsInt()    @Min(0)    age: number;}const input: any = {    firstName: "Foo",    age: -1};const inputAsClassInstance = plainToClass(    Person, input as Person);validate(inputAsClassInstance).then(errors => {    // 錯誤處理代碼});

    類型總是同步的。

    需要對類進行檢查時很有用。

    可以用來檢查接口(定義一個實現(xiàn)接口的類)。

    注意:class-validator 用于具體的類實例。在上面的代碼中,我們使用它的姊妹庫 class-transformer 將普通輸入轉換為 Person 實例。轉換過程本身不進行任何類型檢查。

    藍藍設計m.lzhte.cn )是一家專注而深入的界面設計公司,為期望卓越的國內(nèi)外企業(yè)提供卓越的UI界面設計、BS界面設計 、 cs界面設計 、 ipad界面設計 、 包裝設計 、 圖標定制 、 用戶體驗 、交互設計、 網(wǎng)站建設 平面設計服務

    日歷

    鏈接

    個人資料

    藍藍設計的小編 http://m.lzhte.cn

    存檔

    主站蜘蛛池模板: 亚洲欧洲日产国码无码av野外| 亚洲另类丝袜综合网| 日本中文字幕有码在线视频| 曰曰摸夜夜添夜夜添高潮出水| 国产亚洲欧美另类一区二区三区| 一本大道中文日本香蕉| 91在线日韩在线播放| 在线观看网址入口2020国产 | 欧美XXXX做受欧美| 亚洲最大国产精品黄色| 精品亚洲成A人在线观看青青| 国产91在线|日本| 国产中文字幕日韩精品| 在线观看精品视频网站| 日本成人| 久久无码精品精品古装毛片| 国产亚洲麻豆一二三区| 国产精品手机在线播放| 中文字幕在线观看日本| 狠狠色噜噜狠狠狠狠2018| 人妻人人澡人人添人人爽人人玩 | 狠狠做五月深爱婷婷伊人| a级片免费| 9l国产精品久久久久麻豆| 女人国产香蕉久久精品| 尼玛县| 亚洲高清国产精品拍青青草原| 亚洲精品久久久狠狠爱小说| 欧美精品不卡一区二区三区| 德清县| 996久久国产精品线观看导航| 午夜精品久久久久9999高清| 黄页网址大全免费观看视频国产 | 国产午夜人做人免费视频| AV边做边流奶水无码免费| 国产AV高清精品久久| 遂溪县| 国产精品极品自拍视频| 欧美性bbbbbxxxxxddd| 精品国产三级大全在线观看| 99成人福利免费视频|