国产精品美女久久久浪潮AV,国产精品三级一二三区,久久精品国产一区二区小说 ,依依成人影视国产精品,全部无卡免费的毛片在线看,日本一区二区三深夜不卡,国产精品女同一区二区久久,国产精品夜色一区二区三区

        TypeScript 運(yùn)行時(shí)類(lèi)型檢查指南

        2020-7-10    seo達(dá)人

        為什么需要額外的類(lèi)型檢查?

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


        運(yùn)行時(shí)檢查的嚴(yán)格性

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

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

        運(yùn)行時(shí)類(lèi)型檢查策略

        定制代碼手動(dòng)檢查

        靈活

        可能比較枯燥,容易出錯(cuò)

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

        使用校驗(yàn)庫(kù)手動(dòng)檢查

        比如使用 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()});

        靈活

        容易編寫(xiě)

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

        手動(dòng)創(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    }  }}

        使用標(biāo)準(zhǔn)格式,有大量庫(kù)可以校驗(yàn)。

        JSON 很容易存儲(chǔ)和復(fù)用。

        可能會(huì)很冗長(zhǎng),手寫(xiě) JSON Schema 可能會(huì)很枯燥。

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

        自動(dòng)創(chuàng)建 JSON Schema

        基于 TypeScript 代碼生成 JSON Schema

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

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

        基于 JSON 輸入示例生成

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

        -- 如果提供的 JSON 輸入示例和實(shí)際輸入不一致,可能導(dǎo)致錯(cuò)誤。

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

        轉(zhuǎn)譯

        例如使用 ts-runtime。


        這種方式會(huì)將代碼轉(zhuǎn)譯成功能上等價(jià)但內(nèi)置運(yùn)行時(shí)類(lèi)型檢查的代碼。


        比如,下面的代碼:


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

        會(huì)被轉(zhuǎn)譯為:


        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});

        這一方式的缺陷是無(wú)法控制在何處進(jìn)行運(yùn)行時(shí)檢查(我們只需在輸入輸出的邊界處進(jìn)行運(yùn)行時(shí)類(lèi)型檢查)。


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


        運(yùn)行時(shí)類(lèi)型派生靜態(tài)類(lèi)型

        比如使用 io-ts 這個(gè)庫(kù)。


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


        運(yùn)行時(shí)類(lè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')})

        從中提取相應(yīng)的靜態(tài)類(lèi)型:


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

        以上類(lèi)型等價(jià)于:


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

        類(lèi)型總是同步的。

        io-ts 很強(qiáng)大,比如支持遞歸類(lèi)型。

        需要將類(lèi)型定義為 io-ts 運(yùn)行時(shí)類(lèi)型,這在定義類(lèi)時(shí)不適用:

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

        不容易復(fù)用接口(比如前后端之間使用同一接口),因?yàn)檫@些接口是 io-ts 類(lèi)型而不是普通的 TypeScript 類(lèi)型。

        基于裝飾器的類(lèi)校驗(yàn)

        比如使用 class-validator 這個(gè)庫(kù)。


        基于類(lèi)屬性的裝飾器。

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

        -- 此類(lèi) Java EE 風(fēng)格的庫(kù)還有 typeorm (ORM 庫(kù),類(lèi)似 Java 的 JPA)和 routing-controllers (用于定義 API,類(lèi)似 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 => {    // 錯(cuò)誤處理代碼});

        類(lèi)型總是同步的。

        需要對(duì)類(lèi)進(jìn)行檢查時(shí)很有用。

        可以用來(lái)檢查接口(定義一個(gè)實(shí)現(xiàn)接口的類(lèi))。

        注意:class-validator 用于具體的類(lèi)實(shí)例。在上面的代碼中,我們使用它的姊妹庫(kù) class-transformer 將普通輸入轉(zhuǎn)換為 Person 實(shí)例。轉(zhuǎn)換過(guò)程本身不進(jìn)行任何類(lèi)型檢查。

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

        日歷

        鏈接

        個(gè)人資料

        存檔

        主站蜘蛛池模板: 亚洲av无码精品色午夜app| 永年县| 成年视频| 爱情岛论坛亚洲永久入口口| 精品国产乱码久久久久久| a级毛片无码免费真人久久| 新版天堂在线| 十八禁在线观看视频播放免费| 15gay男同志同性1069| 好男人2019在线视频播放观看| 国产精品香港三级国产av| 亚洲一区二区三区成人网站| 四虎成人精品永久免费av| av在线亚洲欧洲日产一区二区| 欧美丰满熟妇aaaaa片| 久久久人人人婷婷色东京热| 成 人 免费 在线电影| 丰满人妻熟妇乱又伦精品视| 欧美日韩免费做爰大片人| 亚洲小说图区综合在线| chinesefree高潮抽搐| 综合亚洲伊人午夜网| 伊人精品成人久久综合全集观看| 精品国产第一福利网站| 人妻少妇看a偷人无码| 资源县| 免费观看片| 吃瓜爆料就看黑料社区| 精品精品国产高清a级毛片| 免费人成视频网站在线观看18| 中文字幕色av一区二区三区| 最近中文字幕mv免费高清在线| 婷婷综合缴情亚洲| 免费120秒体验试看5次| 大香伊蕉在人线国产免费| 在线视频免费观看www动漫| 午夜精品在线不卡| 我要看www免费看插插视频| 亚洲国产精品久久精品| 亚洲国产精品无码成人片久久| 人妻 丝袜美腿 中文字幕|