国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

從 JavaScript 到 TypeScript

roundstones / 1165人閱讀

摘要:能夠根據返回語句自動推斷出返回值類型,因此我們通常省略它。定義的函數類型接口就像是一個只有參數列表和返回值類型的函數定義。可索引類型具有一個索引簽名,它描述了對象索引的類型,還有相應的索引返回值類型。

本文首發在我的個人博客:http://muyunyun.cn/posts/66a5...
文中的案例代碼已經上傳到 TypeScript

TypeScript 并不是一個完全新的語言, 它是 JavaScript 的超集,為 JavaScript 的生態增加了類型機制,并最終將代碼編譯為純粹的 JavaScript 代碼。

TypeScript 簡介

TypeScript 由 Microsoft(算上 Angular 2 的話加上 Google)開發和維護的一種開源編程語言。 它支持 JavaScript 的所有語法和語義,同時通過作為 ECMAScript 的超集來提供一些額外的功能,如類型檢測和更豐富的語法。下圖顯示了 TypeScript 與 ES5,ES2015,ES2016 之間的關系。

使用 TypeScript 的原因

JavaScript 是一門弱類型語言,變量的數據類型具有動態性,只有執行時才能確定變量的類型,這種后知后覺的認錯方法會讓開發者成為調試大師,但無益于編程能力的提升,還會降低開發效率。TypeScript 的類型機制可以有效杜絕由變量類型引起的誤用問題,而且開發者可以控制對類型的監控程度,是嚴格限制變量類型還是寬松限制變量類型,都取決于開發者的開發需求。添加類型機制之后,副作用主要有兩個:增大了開發人員的學習曲線,增加了設定類型的開發時間。總體而言,這些付出相對于代碼的健壯性和可維護性,都是值得的。

此外,類型注釋是 TypeScript 的內置功能之一,允許文本編輯器和 IDE 可以對我們的代碼執行更好的靜態分析。 這意味著我們可以通過自動編譯工具的幫助,在編寫代碼時減少錯誤,從而提高我們的生產力。

對 TypeScript 的簡介到此,接下來對其特有的知識點進行簡單概括總結,(網上很多教程實際上把 ES6, ES7 的知識點也算進 ts 的知識點了,當然這沒錯~)

數據類型 String 類型

一個保存字符串的文本,類型聲明為 string。可以發現類型聲明可大寫也可小寫,后文同理。

let name: string = "muyy"
let name2: String = "muyy"
Boolen 類型

boolean是 true 或 false 的值,所以 let isBool3: boolean = new Boolean(1) 就會編譯報錯,因為 new Boolean(1) 生成的是一個 Bool 對象。

let isBool1: boolean = false
Number 類型
let number: number = 10;
Array 類型

數組是 Array 類型。然而,因為數組是一個集合,我們還需要指定在數組中的元素的類型。我們通過 Array or type[] 語法為數組內的元素指定類型

let arr:number[] = [1, 2, 3, 4, 5];
let arr2:Array = [1, 2, 3, 4, 5];

let arr3:string[] = ["1","2"];
let arr4:Array = ["1","2"];
Enums 類型

列出所有可用值,一個枚舉的默認初始值是0。你可以調整一開始的范圍:

enum Role {Employee = 3, Manager, Admin}
let role: Role = Role.Employee
console.log(role) // 3
Any 類型

any 是默認的類型,其類型的變量允許任何類型的值:

let notSure:any = 10;
let notSure2:any[] = [1,"2",false];
Void 類型

JavaScript 沒有空值 Void 的概念,在 TypeScirpt 中,可以用 void 表示沒有任何返回值的函數:

function alertName(): void {
  console.log("My name is muyy")
}
函數 為函數定義類型

我們可以給每個參數添加類型之后再為函數本身添加返回值類型。 TypeScript能夠根據返回語句自動推斷出返回值類型,因此我們通常省略它。下面函數 add, add2, add3 的效果是一樣的,其中是 add3 函數是函數完整類型。

function add(x: string, y: string): string{
    return "Hello TypeScript";
}

let add2 = function(x: string, y: string): string{
    return "Hello TypeScript";
}

let add3: (x: string, y: string) => string = function(x: string, y: string): string{
    return "Hello TypeScript";
}
可選參數和默認參數

JavaScript 里,每個參數都是可選的,可傳可不傳。 沒傳參的時候,它的值就是 undefined 。 在 TypeScript 里我們可以在參數名旁使用?實現可選參數的功能。 比如,我們想讓 lastname 是可選的:

function buildName(firstName: string, lastname?: string){
    console.log(lastname ? firstName + "" + lastname : firstName)
}

let res1 = buildName("鳴","人"); // 鳴人
let res2 = buildName("鳴"); // 鳴
let res3 = buildName("鳴", "人", "君"); // Supplied parameters do not match any signature of call target.

如果帶默認值的參數出現在必須參數前面,用戶必須明確的傳入 undefined 值來獲得默認值。 例如,我們重寫上例子,讓 firstName 是帶默認值的參數:

function buildName2(firstName = "鳴", lastName?: string){
    console.log(firstName + "" + lastName)
}

let res4 = buildName2("人"); // undefined人
let res5 = buildName2(undefined, "人"); // 鳴人

傳統的JavaScript程序使用函數和基于原型的繼承來創建可重用的組件,但對于熟悉使用面向對象方式的程序員來講就有些棘手,因為他們用的是基于類的繼承并且對象是由類構建出來的。 從ECMAScript 2015,也就是ECMAScript 6開始,JavaScript程序員將能夠使用基于類的面向對象的方式。 使用TypeScript,我們允許開發者現在就使用這些特性,并且編譯后的JavaScript可以在所有主流瀏覽器和平臺上運行,而不需要等到下個JavaScript版本。

class Person{
    name:string; // 這個是對后文this.name類型的定義
    age:number;
    constructor(name:string,age:number){
        this.name = name;
        this.age = age;
    }
    print(){
        return this.name + this.age;
    }
}

let person:Person = new Person("muyy",23)
console.log(person.print()) // muyy23

我們在引用任何一個類成員的時候都用了 this。 它表示我們訪問的是類的成員。其實這本質上還是 ES6 的知識,只是在 ES6 的基礎上多上了對 this 字段和引用參數的類型聲明。

繼承
class Person{
    public name:string;  // public、private、static 是 typescript 中的類訪問修飾符
    age:number;
    constructor(name:string,age:number){
        this.name = name;
        this.age = age;
    }
    tell(){
        console.log(this.name + this.age);
    }
}

class Student extends Person{
    gender:string;
    constructor(gender:string){
        super("muyy",23);
        this.gender = gender;
    }
    tell(){
        console.log(this.name + this.age + this.gender);
    }
}

var student = new Student("male");
student.tell();  // muyy23male

這個例子展示了 TypeScript 中繼承的一些特征,可以看到其實也是 ES6 的知識上加上類型聲明。不過這里多了一個知識點 —— 公共,私有,以及受保護的修飾符。TypeScript 里,成員默認為 public ;當成員被標記成 private 時,它就不能在聲明它的類的外部訪問;protected 修飾符與private 修飾符的行為很相似,但有一點不同,protected 成員在派生類中仍然可以訪問。

存儲器

TypeScript 支持通過 getters/setters 來截取對對象成員的訪問。 它能幫助你有效的控制對對象成員的訪問。

對于存取器有下面幾點需要注意的:
首先,存取器要求你將編譯器設置為輸出 ECMAScript 5 或更高。 不支持降級到 ECMAScript 3。 其次,只帶有 get 不帶有 set 的存取器自動被推斷為 readonly。 這在從代碼生成 .d.ts 文件時是有幫助的,因為利用這個屬性的用戶會看到不允許夠改變它的值。

class Hello{
    private _name: string;
    private _age: number;
    get name(): string {
        return this._name;
    }
    set name(value: string) {
        this._name = value;
    }
    get age(): number{
        return this._age;
    }
    set age(age: number) {
        if(age>0 && age<100){
            console.log("年齡在0-100之間"); // 年齡在0-100之間
            return;
        }
        this._age = age;
    }
}

let hello = new Hello();
hello.name = "muyy";
hello.age = 23
console.log(hello.name); // muyy
接口 接口

TypeScript的核心原則之一是對值所具有的結構進行類型檢查。在TypeScript里,接口的作用就是為這些類型命名和為你的代碼或第三方代碼定義契約。

interface LabelValue{
    label: string;
}

function printLabel(labelObj: LabelValue){
    console.log(labelObj.label);
}

let myObj = {
    "label":"hello Interface"
};
printLabel(myObj);

LabelledValue 接口就好比一個名字,它代表了有一個 label 屬性且類型為 string 的對象。只要傳入的對象滿足上述必要條件,那么它就是被允許的。

另外,類型檢查器不會去檢查屬性的順序,只要相應的屬性存在并且類型也是對的就可以。

可選屬性

帶有可選屬性的接口與普通的接口定義差不多,只是在可選屬性名字定義的后面加一個 ? 符號。可選屬性的好處之一是可以對可能存在的屬性進行預定義,好處之二是可以捕獲引用了不存在的屬性時的錯誤。

interface Person{
    name?:string;
    age?:number;
}

function printInfo(info:Person){
    console.log(info);
}

let info = {
    "name":"muyy",
    "age":23
};

printInfo(info); // {"name": "muyy", "age": 23}

let info2 = {
    "name":"muyy"
};

printInfo(info2); // {"name": "muyy"}
函數類型

接口能夠描述 JavaScript 中對象擁有的各種各樣的外形。 除了描述帶有屬性的普通對象外,接口也可以描述函數類型。定義的函數類型接口就像是一個只有參數列表和返回值類型的函數定義。參數列表里的每個參數都需要名字和類型。定義后完成后,我們可以像使用其它接口一樣使用這個函數類型的接口。

interface SearchFunc{
    (source: string, subString: string): boolean;
}

let mySearch: SearchFunc;
mySearch = function(source: string,subString: string){
    return source.search(subString) !== -1;
};

console.log(mySearch("鳴人","鳴")); // true
console.log(mySearch("鳴人","纓")); // false
可索引類型

與使用接口描述函數類型差不多,我們也可以描述那些能夠“通過索引得到”的類型,比如 a[10]ageMap["daniel"]。 可索引類型具有一個索引簽名,它描述了對象索引的類型,還有相應的索引返回值類型。 讓我們看如下例子:

interface StringArray{
    [index: number]: string;
}

let MyArray: StringArray;
MyArray = ["是","云","隨","風"];
console.log(MyArray[2]); // 隨
類類型

與 C# 或 Java 里接口的基本作用一樣,TypeScript 也能夠用它來明確的強制一個類去符合某種契約。

我們可以在接口中描述一個方法,在類里實現它,如同下面的 setTime 方法一樣:

interface ClockInterface{
    currentTime: Date;
    setTime(d: Date);
}

class Clock implements ClockInterface{
    currentTime: Date;
    setTime(d: Date){
        this.currentTime = d;
    }
    constructor(h: number, m: number) {}
}
繼承接口

和類一樣,接口也可以相互繼承。 這讓我們能夠從一個接口里復制成員到另一個接口里,可以更靈活地將接口分割到可重用的模塊里。

interface Shape{
    color: string;
}

interface PenStroke{
    penWidth: number;
}

interface Square extends Shape,PenStroke{
    sideLength: number;
}

let s = {};
s.color = "blue";
s.penWidth = 100;
s.sideLength = 10;
模塊

TypeScript 與 ECMAScript 2015 一樣,任何包含頂級 import 或者 export 的文件都被當成一個模塊。

export interface StringValidator{
    isAcceptable(s:string): boolean;
}

var strReg = /^[A-Za-z]+$/;
var numReg = /^[0-9]+$/;

export class letterValidator implements StringValidator{
    isAcceptable(s:string): boolean{
        return strReg.test(s);
    }
}

export class zipCode implements StringValidator{
    isAcceptable(s: string): boolean{
        return s.length == 5 && numReg.test(s);
    }
}
泛型

軟件工程中,我們不僅要創建一致的定義良好的 API ,同時也要考慮可重用性。 組件不僅能夠支持當前的數據類型,同時也能支持未來的數據類型,這在創建大型系統時為你提供了十分靈活的功能。
在像 C# 和 Java 這樣的語言中,可以使用泛型來創建可重用的組件,一個組件可以支持多種類型的數據。 這樣用戶就可以以自己的數據類型來使用組件。

初探泛型

如下代碼,我們給 Hello 函數添加了類型變量 T ,T 幫助我們捕獲用戶傳入的類型(比如:string)。我們把這個版本的 Hello 函數叫做泛型,因為它可以適用于多個類型。 代碼中 outputoutput2 是效果是相同的,第二種方法更加普遍,利用了類型推論 —— 即編譯器會根據傳入的參數自動地幫助我們確定T的類型:

function Hello(arg:T):T{
    return arg;
}

let outPut = Hello("Hello Generic");
let output2 = Hello("Hello Generic")

console.log(outPut);
console.log(outPut2);
參考資料

TypeScript 中文文檔

TypeScript

TypeScript for Angular 2 - Part 1 (An Introduction)

文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。

轉載請注明本文地址:http://specialneedsforspecialkids.com/yun/83804.html

相關文章

  • JavaScript TypeScript - 聲明類型

    摘要:要為變量或者常量指定類型也很簡單,就是在變量常量名后面加個冒號,再指定類型即可,比如聲明函數是類型,即返回值是類型聲明參數是類型聲明是無返回值的聲明是這段代碼演示了對函數類型參數類型和變量類型地聲明。變量函數參數和返回值需要申明類型。 從 JavaScript 語法改寫為 TypeScript 語法,有兩個關鍵點,一點是類成員變量(Field)需要聲明,另一點是要為各種東西(變量、參數...

    Flands 評論0 收藏0
  • React項目JavascriptTypescript的遷移經驗總結

    摘要:面對越來越火的,我們公司今年也逐漸開始擁抱。綜上所述,我個人覺得是要刪除相關的東西,降低項目復雜度。但是有一個例外情況。這個配置項有三個值可選擇,分別是和。模式會生成,在使用前不需要再進行轉換操作了,輸出文件的擴展名為。 拋轉引用 現在越來越多的項目放棄了javascript,而選擇擁抱了typescript,就比如我們熟知的ant-design就是其中之一。面對越來越火的typesc...

    zhisheng 評論0 收藏0
  • JavaScript TypeScript - 模塊化和構建

    摘要:不過,相對于靜態類型檢查帶來的好處,這些代價是值得的。當然少不了的模塊化標準,雖然到目前為止和大部分瀏覽器都還不支持它。本身支持兩種模塊化方式,一種是對的模塊的微小擴展,另一種是在發布之前本身模仿的命名空間。有一種情況例外。 TypeScript 帶來的最大好處就是靜態類型檢查,所以在從 JavaScript 轉向 TypeScript 之前,一定要認識到添加類型定義會帶來額外的工作量...

    Jonathan Shieber 評論0 收藏0
  • JavaScript TypeScript - 接口

    摘要:前面講泛型的時候,提到了接口。和泛型一樣,接口也是目前中并不存在的語法。不過可不吃這一套,所以這里通過注釋關閉了對該接口的命名檢查。這樣的接口不能由類實現。 前面講 泛型 的時候,提到了接口。和泛型一樣,接口也是目前 JavaScript 中并不存在的語法。 由于泛型語法總是附加在類或函數語法中,所以從 TypeScript 轉譯成 JavaScript 之后,至少還存在類和函數(只是...

    darkbaby123 評論0 收藏0

發表評論

0條評論

最新活動
閱讀需要支付1元查看
<