學(xué)習(xí) typescript 基礎(chǔ)語(yǔ)法

typescript

  • 安裝 npm install -g typescript

編譯

  • tsc 文件名

TypeScript 的原始數(shù)據(jù)類型

  • string蛛枚,number 谅海,Boolean ,null蹦浦,undefined胁赢,enum ,symbol

  • null,undefined 是其它類型的子類型,其它類型可以賦值為這兩個(gè)類型

  • void 無(wú)返回值的意思

任意值 any 可以賦值為任意類型

  • 不給變量指定類型白筹,就會(huì)被認(rèn)為是任意類型智末,跟原生 js 一樣

當(dāng)給一個(gè)變量賦初始值的時(shí)候,它會(huì)根據(jù)你的值判斷你的類型

  • 沒(méi)有賦值就是任意類型徒河,賦值會(huì)類型推導(dǎo)

聯(lián)合類型

var b:string | number = 1

  • 只能訪問(wèn)此聯(lián)合類型的 共有方法

對(duì)象類型

interface Istate {
name: string
}

  • 只能強(qiáng)約束對(duì)象的屬性值和屬性個(gè)數(shù)

如果其中一個(gè)類型 可有可無(wú) ?

interface Istate {
name: string, // 也可以 string | number
age?: number
}

屬性個(gè)數(shù)不確定

interface Istate {
name: string,
[propName: string]: any
}

  • any 是必須的

只讀屬性

interface Istate2 {
name: string,
readonly age: number
}

var obj2:Istate2 = { name: '11', age: 1 }
obj2 = { name: '1243', age: 23 }
obj2.age = 1 // 錯(cuò)誤

數(shù)組

  • 類型加 [] 表示法
    var ary:number []= [1,2,3]
    var ary2:any [] = [1,2,'3']

  • 數(shù)組泛型 Array<數(shù)組類型>
    var aryType:Array<Number> = [1,2,3]

  • 接口表示法 可以和對(duì)象類型 混用

interface IArr {
[index: number]: Istate2
}
var interAry:IArr = [{ name: 'hhh', age: 1 }]

var arrType2: Array<Istate2> = [{ name: 'hhh', age: 1 }]
var arrType3:Istate2 [] = [{ name: 'hhh', age: 1 }]

函數(shù)類型

function fun1(name: string, age:number) {
return age
}

fun1('123',123)
const ages:number = fun1('dsf', 123)

  • 可有可無(wú)
    function fun2(name: string, age:number, sex?:string) {
    return age
    }

  • 默認(rèn)值
    function fun3(name: string = 'type', age:number, sex?:string) {
    return age
    }

表達(dá)式的方式

var funa = function(name:string, age:number = 20):number { // number 返回類型
return age
}

  • 變量的類型 約束 + 返回值的類型
    var funa2:(name: string, age: number) => number = function(name: string, age: number) {
    return age
    }

  • interface 的方式
    interface funType3 {
    (name: string, age: number): number
    }

var funa3:funType3 = function(name: string, age: number):number {
return age
}

  • 重載的方式 定義輸入類型和返回類型相同 系馆,輸入是什么類型,返回值是什么類型
    // 輸入是 number顽照,輸出也是 number
    function getValue(value: number):number;
    function getValue(value: string):string;
    function getValue(value:string|number):number|string {
    return value
    }
    var res1:number = getValue(1)
    var res2:string = getValue('2')

類型斷言

  • 因?yàn)橹荒芊祷貎蓚€(gè)參數(shù)共有方法由蘑,如果不想用共同方法闽寡,可以使用類型斷言
    function getAssert(name: string | number) {
    // return (<string>name).length

    return (name as string).length
    }
  • 但在 tsx 中只能是使用 return (name as string).length <> 會(huì)導(dǎo)致 tsx 解析錯(cuò)誤

ts 中聲明文件 ,引入第三方包

  • 例如使用 jQuery
    • 聲明 declare var $:(selector:string)=> any
    • 引入 /// <reference path="...ts"/>
      declare var $:(selector:string)=> any

js 類型別名 type

type str = string
var str5:str = "1"

type muchType = string | number | boolean
var str6 = false

  • 接口類型
    interface muchType2 {
    name: string,
    str: number
    }

interface muchType3 {
name: string,
age: number
}

type muchType4 = muchType2 | muchType3

  • 限定字符串
    // 限定字符串
    type myStr = '我' | '你'

function getSelf(self: myStr) {

}

getSelf('我')

枚舉類型

  • 枚舉
    enum nums {
    'one',
    'two',
    'three',
    'four',
    'five'
    }

nums[1] == 'two' // true
mums.two

類 class

class Person {
private name = 'hello'
age = 20
protected sex = '女'
speak() {
console.log('我是' + this.name + '我多大了?' + this.age)
}
}

var p = new Person()
p.speak()

console.log(p.name) // ?
console.log(p.age)
console.log(p.sex) // ?

  • public 是共有屬性尼酿,都可以訪問(wèn)
  • private 是私有屬性爷狈,只有內(nèi)部可以調(diào)用
  • protected 受保護(hù)的屬性,允許子類訪問(wèn)

class Child extends Person {

callPerent() {
console.log(super.age)
console.log(super.sex)
}
}

泛型

function resArray<T>(length: number, value:T):Array<T> {
let ary = []
for (let i = 0; i < length; i++) {
ary[i] = value
}
return ary
}

resArray(3, '1') // 如果不定義類型裳擎,就會(huì)自動(dòng)類型推導(dǎo)
resArray<String>(1, '1') // 可以傳遞類型
var arrVal: string [] = resArray(2, '1')

  • interface 使用泛型

interface FXFun {
<T>(name:string, value: T): Array<T>
}

var func5: FXFun

func5 = function<T>(name: string, value: T): T [] {
return []
}

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末涎永,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子鹿响,更是在濱河造成了極大的恐慌羡微,老刑警劉巖,帶你破解...
    沈念sama閱讀 212,718評(píng)論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件惶我,死亡現(xiàn)場(chǎng)離奇詭異妈倔,居然都是意外死亡竭贩,警方通過(guò)查閱死者的電腦和手機(jī)层亿,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,683評(píng)論 3 385
  • 文/潘曉璐 我一進(jìn)店門(mén)杠步,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)被盈,“玉大人,你說(shuō)我怎么就攤上這事篙程⌒炕” “怎么了蝙砌?”我有些...
    開(kāi)封第一講書(shū)人閱讀 158,207評(píng)論 0 348
  • 文/不壞的土叔 我叫張陵叉跛,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我蒸殿,道長(zhǎng)筷厘,這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 56,755評(píng)論 1 284
  • 正文 為了忘掉前任宏所,我火速辦了婚禮酥艳,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘爬骤。我一直安慰自己充石,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,862評(píng)論 6 386
  • 文/花漫 我一把揭開(kāi)白布霞玄。 她就那樣靜靜地躺著骤铃,像睡著了一般。 火紅的嫁衣襯著肌膚如雪坷剧。 梳的紋絲不亂的頭發(fā)上惰爬,一...
    開(kāi)封第一講書(shū)人閱讀 50,050評(píng)論 1 291
  • 那天,我揣著相機(jī)與錄音惫企,去河邊找鬼撕瞧。 笑死陵叽,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的丛版。 我是一名探鬼主播巩掺,決...
    沈念sama閱讀 39,136評(píng)論 3 410
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼页畦!你這毒婦竟也來(lái)了胖替?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書(shū)人閱讀 37,882評(píng)論 0 268
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤寇漫,失蹤者是張志新(化名)和其女友劉穎刊殉,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體州胳,經(jīng)...
    沈念sama閱讀 44,330評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡记焊,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,651評(píng)論 2 327
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了栓撞。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片遍膜。...
    茶點(diǎn)故事閱讀 38,789評(píng)論 1 341
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖瓤湘,靈堂內(nèi)的尸體忽然破棺而出瓢颅,到底是詐尸還是另有隱情,我是刑警寧澤弛说,帶...
    沈念sama閱讀 34,477評(píng)論 4 333
  • 正文 年R本政府宣布挽懦,位于F島的核電站,受9級(jí)特大地震影響木人,放射性物質(zhì)發(fā)生泄漏信柿。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 40,135評(píng)論 3 317
  • 文/蒙蒙 一醒第、第九天 我趴在偏房一處隱蔽的房頂上張望渔嚷。 院中可真熱鬧,春花似錦稠曼、人聲如沸形病。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 30,864評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)漠吻。三九已至,卻和暖如春司恳,著一層夾襖步出監(jiān)牢的瞬間侥猩,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 32,099評(píng)論 1 267
  • 我被黑心中介騙來(lái)泰國(guó)打工抵赢, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留欺劳,地道東北人唧取。 一個(gè)月前我還...
    沈念sama閱讀 46,598評(píng)論 2 362
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像划提,于是被迫代替她去往敵國(guó)和親枫弟。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,697評(píng)論 2 351