亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

?typeScript入門基礎介紹

 更新時間:2022年02月17日 17:28:21   作者:前端人  
這篇文章主要介紹了?typeScript入門基礎,TypeScript?是由微軟開發(fā)的開源、跨平臺的編程語言,是?javaScript?的超集,最終被編譯為?javaScript代碼。常常被簡稱為TS支持JS、ES語法,下文將繼續(xù)其他基礎介紹,需要的朋友可以參考一下

TS 的特點:

  • 始于 javaScript 歸于 javaScript 。
  • 強大的類型系統(tǒng)。
  • 先進的 javaScript 。
  • 適合開發(fā)大型項目,編譯成純 js 代碼,js 可以運行在任何瀏覽器上。

typeScript 是區(qū)分大小寫的一門語言,本篇文章主要帶你了解 ts 的安裝,環(huán)境配置,以及簡單的入門。

一、安裝 TS

使用之前需要安裝:

npm install -g typescript

安裝完成之后,使用 tsc -v 檢查安裝之后的版本。

第一個 ts 文件:01.ts,代碼如下:

(()=>{
?function show(msg){
? return "字符串:"+msg
?}
?let str = "前端"
?console.log(show(str))
})()

通過 script 引入 html 文件

<script ?src="./01.ts"></script>

頁面正常運行,因為 ts 能夠支持 js 語法,所以文件內直接引入使用是沒問題的,除此之外,還可以使用 node 命令運行該文件,也是可以正常執(zhí)行的。

如果此時,在 ts 文件內加入 ts 語法:

// 添加類型支持
(()=>{
?function show(msg:string){
? //添加 string 的意義在于傳入的 msg值只能是字符串,不可以是其他類型
? return "字符串:"+msg
?}
?let str = "前端"
?console.log(show(str))
})()

此時瀏覽器運行時,會報錯,無法繼續(xù)執(zhí)行。

此時就需要將 ts 文件編譯為 js 文件,打開命令行工具,運行:

tsc 01.ts

運行后會自動生成一個 01.js 文件,查看js代碼內容如下:

function show(msg) {
?return "字符串:" + msg;
}
(function () {
?var str = "前端";
?console.log(show(str));
})();

總結:

  • ts 文件內直接輸入 js 文件,在 html 文件引入 ts 文件,在瀏覽器內是可以直接運行的。
  • ts 文件內如果有 ts 語法代碼,若在 html 文件內引入 ts 文件,直接在瀏覽器運行會報錯,此時需要先編譯為 js 文件。
  • 在 ts 文件函數(shù)中的形參,如果使用了某個類型進行修飾,那么在最終編譯的 js 文件中是沒有該類型的。
  • ts 內地 let 修飾符,編譯后的 js 文件內變成了 var 。

二、Vscode 自動編譯 ts

新建一個項目目錄,當前目錄下打開命令行工具,執(zhí)行

tsc --init

自動生成 tsconfig.json 文件,代碼如下:

{
?"compilerOptions": {
? "target": "es2016", ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?
? "module": "commonjs", ? ? ? ? ? ? ? ? ? ? ? ? ? ? ??
? "outDir": "./js", ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?
? "esModuleInterop": true, ? ? ? ? ? ? ? ? ? ? ? ? ? ??
? "forceConsistentCasingInFileNames": true, ? ? ?
? "strict": true, ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?
? "skipLibCheck": true ? ? ? ? ? ? ? ? ? ? ? ? ? ? ??
?}
}

注:

outDir 表示的是 ts 文件編譯之后生成 js 文件的存放目錄。如果屬性值之后的文件夾不存在時,就會自動創(chuàng)建。

strict 表示是嚴格模式。

新建 index.ts 文件,代碼如下:

(() => {
?function showStr(str:string) {
? return str?
?}
?let a: string = "前端人"
?// 調用函數(shù)
?console.log("a",showStr(a));
})()

類型注解:函數(shù)地形參后加修飾符,用來限制傳入參數(shù)的類型,string 表示只能為字符串類型。

在命令行運行

tsc -w?
//或
tsc -watch

自動生成 js 文件夾,包括 index.js 文件。運行該命令后,只要 ts 文件發(fā)生改變,就會自動編譯。

一切運行正常,沒有任何錯誤。

如果調用函數(shù)的參數(shù)傳為數(shù)值時:

console.log(showStr(123));

此時編輯器內報錯:類型“number”的參數(shù)不能賦給類型“string”的參數(shù)。

ts 能夠智能提示問題,是因為 ts 提供了靜態(tài)代碼分析,可以分析代碼結構和提供的類型注解。

但是 tsc 編譯的時候,雖然會提示錯誤,但它依舊會編譯為 js 文件,js 在執(zhí)行的時候不會報錯,因為 js 是弱類型語言。

三、入門 TS

基礎數(shù)據類型

  • 為布爾值類型。如:let isDone: boolean = false;
  • number 為數(shù)值類型,ts 能夠支持二、八、十、十六進制數(shù)據。如:let decLiteral: number = 6;
  • string 為字符串類型。如:let name: string = "bob";
  • 表示數(shù)組類型。數(shù)組名后加元素類型[] 加 數(shù)組值。如:let list: number[] = [1, 2, 3];
  • 元組類型。如:let arr:[string,number,boolean] = ['str',1,true]
  • 枚舉,為一組數(shù)值賦予友好名字。如:enum Color { red, green, blue }
  • 任意類型,有時不確定傳入的值是什么類型,就可以使用 any 類型。如:let notSure:any = 1
  • 空值,與 any 正好相反,表示沒有任何類型。 如:function show():void { }
  • null undefined
  • never 類型,表示永不存在的值。function error(message: string): never { throw new Error(message); }

接口

接口簡單點講就是一種約束。在 ts 里,接口的作用就是為這些類型命名和為你的代碼或第三方代碼定義契約。

TypeScript 中的接口是一個非常靈活的概念,除了可用于對類的一部分行為進行抽象以外,也常用于對「對象的形狀(Shape)」進行描述。

使用形式:

(() => {
?//定義一個接口
?interface Person{
? firstName:string,//添加類型限定
? lastName:string
?}
?function showFullName(person:Person) {
? // 添加類型限定之后,內部會自動提示接口內的字段
? return person.firstName + '_' + person.lastName
?}
?const p = {
? firstName: "Hello",
? lastName: "World"
?}
?console.log("姓名",showFullName(p));
})()

如果把 p 中的 firstName 注釋掉,就會報錯,提示:

在本實例中,接口的意義就是限定傳入 showFullName 函數(shù)內的數(shù)據屬性的限制。

接口優(yōu)點:自動檢測傳入的數(shù)據是否符合接口規(guī)范,如果不符合則會報錯。

Typescript類介紹

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

ts 的類只是一個語法糖,本質還是 js 函數(shù)實現(xiàn)的。

使用示例:

(() => {
? //定義一個接口
? interface Person{
? ? firstName: string,
? ? lastName:string
? }
? //定義一個類
? class Personal {
? ? //定義公共的字段屬性
? ? firstName: string
? ? lastName: string
? ? fullName: string
? ? // 構造函數(shù)
? ? constructor(firstName: string,lastName:string) {
? ? ? //更新屬性數(shù)據
? ? ? this.firstName = firstName
? ? ? this.lastName = lastName
? ? ? this.fullName = this.firstName + this.lastName
? ? }
? }
??
? const p = new Personal('你','好')
??
? function showFullName(person: Person) {
? ? return person.firstName + person.lastName
? }
? console.log("p",showFullName(p));
})()

到此這篇關于 typeScript入門基礎介紹的文章就介紹到這了,更多相關 typeScript內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • 函數(shù)式編程入門實踐(一)

    函數(shù)式編程入門實踐(一)

    這篇文章主要介紹了Javascript函數(shù)式編程,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-04-04
  • 如何在webpack項目中調試loader插件

    如何在webpack項目中調試loader插件

    最近在學習webpack,本文主要介紹了loader插件的調試方法,需要的朋友們下面隨著小編來一起學習學習吧
    2021-06-06
  • iframe 異步加載技術及性能分析

    iframe 異步加載技術及性能分析

    我們會經常使用iframes來加載第三方的內容、廣告或者插件。使用iframe是因為他可以和主頁面并行加載,不會阻塞主頁面。
    2011-07-07
  • layui table 表格模板按鈕的實例代碼

    layui table 表格模板按鈕的實例代碼

    今天小編就為大家分享一篇layui table 表格模板按鈕的實例代碼,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-09-09
  • 取得傳值的函數(shù)

    取得傳值的函數(shù)

    取得傳值的函數(shù)...
    2006-10-10
  • js相冊效果代碼(點擊創(chuàng)建即可)

    js相冊效果代碼(點擊創(chuàng)建即可)

    利用js 書寫的相冊代碼,點擊創(chuàng)建即可看到效果,感興趣的朋友可以參考下哈,希望對你學習jquery有所幫助
    2013-04-04
  • JavaScript實現(xiàn)旋轉輪播圖

    JavaScript實現(xiàn)旋轉輪播圖

    這篇文章主要為大家詳細介紹了JavaScript實現(xiàn)旋轉輪播圖,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-08-08
  • Es6 Generator函數(shù)詳細解析

    Es6 Generator函數(shù)詳細解析

    Generator 函數(shù)是 ES6 提供的一種異步編程解決方案,語法行為與傳統(tǒng)函數(shù)完全不同。這篇文章給大家介紹Es6 Generator函數(shù)的相關知識,感興趣的朋友一起看看吧
    2018-02-02
  • 淺析JS中document對象的一些重要屬性

    淺析JS中document對象的一些重要屬性

    本篇文章主要是對JS中document對象的一些重要屬性進行了詳細的介紹,需要的朋友可以過來參考下,希望對大家有所幫助
    2014-03-03
  • await?Streaking解決原理示例詳解

    await?Streaking解決原理示例詳解

    這篇文章主要為大家介紹了await?Streaking解決原理示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-12-12

最新評論