TypeScript對于Duck類型和模塊命名空間應(yīng)用
一.TypeScript 鴨子類型
Duck類型是一種動態(tài)類型和多態(tài)形式。
在這種風(fēng)格中,對象的有效語義不是通過從特定類繼承或?qū)崿F(xiàn)特定接口來確定的,而是通過“當(dāng)前方法和屬性的集合”來確定的。
var object_name = { key1: "value1", // 標(biāo)量 key2: "value", key3: function() { // 函數(shù) }, key4:["content1", "content2"] //集合 }
在duck類型中,重點(diǎn)是對象的行為可以做什么,而不是對象所屬的類型。
例如,在不使用duck類型的語言中,我們可以編寫一個(gè)函數(shù),該函數(shù)接受“duck”類型的對象并調(diào)用其“walk”和“call”方法。
在使用duck類型的語言中,這樣的函數(shù)可以接受任何類型的對象并調(diào)用其“go”和“call”方法。
如果這些需要調(diào)用的方法不存在,則會引發(fā)運(yùn)行時(shí)錯(cuò)誤。具有這種正確的“go”和“call”方法的任何對象都可以被函數(shù)接受。
此行為導(dǎo)致上述表達(dá)式,并將此確定類型的方法命名為鴨子類型。
interface IPoint { x:number y:number } function addPoints(p1:IPoint,p2:IPoint):IPoint { var x = p1.x + p2.x var y = p1.y + p2.y return {x:x,y:y} } // 正確 var newPoint = addPoints({x:3,y:4},{x:5,y:1}) // 錯(cuò)誤 var newPoint2 = addPoints({x:1},{x:4,y:3})
二.TypeScript 命名空間
名稱空間最明確的目的之一是解決重復(fù)名稱的問題。
假設(shè)班上有兩個(gè)叫小明的學(xué)生。為了清楚地區(qū)分他們,我們必須使用他們名字之外的一些附加信息,例如他們的姓氏(王曉明、李曉明)或他們父母的名字。
命名空間定義標(biāo)識符的可見范圍。一個(gè)標(biāo)識符可以在多個(gè)名稱空間中定義,它在不同名稱空間中的含義是無關(guān)的。這樣,任何標(biāo)識符都可以在新名稱空間中定義,并且它們不會與任何現(xiàn)有標(biāo)識符沖突,因?yàn)楝F(xiàn)有定義在其他名稱空間中。
typescript中的命名空間由命名空間定義。語法格式如下:
namespace SomeNameSpaceName { export interface ISomeInterfaceName { } export class SomeClassName { } }
上面定義了一個(gè)名稱空間somenamespacename。
如果我們需要在外部調(diào)用somenamespacename中的類和接口,我們需要向類和接口添加export關(guān)鍵字。
要調(diào)用另一個(gè)命名空間,語法格式為:
SomeNameSpaceName.SomeClassName;
如果命名空間位于單獨(dú)的typescript文件中,則應(yīng)使用三個(gè)斜杠///引用它。
語法格式如下:
/// <reference path = "SomeFileName.ts" />
namespace Drawing { export interface IShape { draw(); } }
名稱空間支持嵌套,也就是說,可以在另一個(gè)名稱空間中定義名稱空間。
namespace Runoob { export namespace invoiceApp { export class Invoice { public calculateDiscount(price: number) { return price * .40; } } } }
三.TypeScript 模塊
typescript模塊設(shè)計(jì)有可替換的組織代碼。
模塊在其自己的范圍內(nèi)執(zhí)行,而不是在全局范圍內(nèi),這意味著模塊中定義的變量、函數(shù)和類在模塊外部不可見,除非它們使用導(dǎo)出顯式導(dǎo)出。
同樣,我們必須導(dǎo)入其他模塊通過導(dǎo)入導(dǎo)出的變量、函數(shù)、類等。
這兩個(gè)模塊之間的關(guān)系是通過在文件級使用導(dǎo)入和導(dǎo)出來建立的。
模塊使用模塊加載器導(dǎo)入其他模塊。在運(yùn)行時(shí),模塊加載器的功能是在執(zhí)行模塊代碼之前查找并執(zhí)行模塊的所有依賴項(xiàng)。最常見的JavaScript模塊加載器是為node JS和require提供服務(wù)。用于web應(yīng)用程序的js。
此外,還有systemjs和webpack。
模塊導(dǎo)出使用關(guān)鍵字export。語法格式如下:
// 文件名 : SomeInterface.ts export interface SomeInterface { // 代碼部分 }
要在其他文件中使用此模塊,需要使用導(dǎo)入關(guān)鍵字進(jìn)行導(dǎo)入:
import someInterfaceRef = require("./SomeInterface");
TestShape.js 文件代碼為:
define(["require", "exports", "./Circle", "./Triangle"], function (require, exports, circle, triangle) { function drawAllShapes(shapeToDraw) { shapeToDraw.draw(); } drawAllShapes(new circle.Circle()); drawAllShapes(new triangle.Triangle()); });
四.類型腳本聲明文件
作為JavaScript的超集,typescript在開發(fā)過程中不可避免地引用了其他第三方JavaScript庫。
雖然可以通過直接引用調(diào)用庫的類和方法,但不能使用類型腳本功能,如類型檢查。
為了解決這個(gè)問題,我們需要?jiǎng)h除這些庫中的函數(shù)和方法體,只保留導(dǎo)出的類型聲明。
相反,將生成描述JavaScript庫和模塊信息的聲明文件。
通過引用此聲明文件,可以借用typescript的各種功能來使用庫文件。
如果我們想使用第三方庫,比如jQuery,我們通常會得到一個(gè)ID為foo的元素,如下所示:
$('#foo'); // 或 jQuery('#foo');
但在typescript中,我們不知道$jQuery是什么:
jQuery('#foo'); // index.ts(1,1): error TS2304: Cannot find name 'jQuery'.
此時(shí),我們需要使用declare關(guān)鍵字定義其類型,以幫助typescript判斷傳入的參數(shù)類型是否正確:
declare var jQuery: (selector: string) => any; jQuery('#foo');
declare定義的類型僅用于編譯時(shí)的檢查,并將從編譯結(jié)果中刪除。
上述示例的編譯結(jié)果是:
聲明文件以 .d.ts 為后綴,例如:
runoob.d.ts
聲明文件或模塊的語法格式如下:
declare module Module_Name { }
Typescript導(dǎo)入聲明文件語法格式:
/// <reference path = " runoob.d.ts" />
到此這篇關(guān)于TypeScript對于Duck類型和模塊命名空間應(yīng)用的文章就介紹到這了,更多相關(guān)TypeScript Duck類型內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
JS基于開關(guān)思想實(shí)現(xiàn)的數(shù)組去重功能【案例】
這篇文章主要介紹了JS基于開關(guān)思想實(shí)現(xiàn)的數(shù)組去重功能,簡單分析了開關(guān)思想的原理,并結(jié)合具體實(shí)例形式分析了javascript基于開關(guān)思想實(shí)現(xiàn)數(shù)組去重相關(guān)操作技巧,需要的朋友可以參考下2019-02-02百度判斷手機(jī)終端并自動跳轉(zhuǎn)js代碼及使用實(shí)例
這篇文章主要介紹了百度判斷手機(jī)終端并自動跳轉(zhuǎn)js代碼及使用實(shí)例,需要的朋友可以參考下2014-06-06聊聊JavaScript中的try...catch使用小技巧
作為一名web前端工程師,JavaScript中的try...catch是我們常用的特性之一,用于處理代碼中可能出現(xiàn)的錯(cuò)誤,本文小編將和大家一起聊聊JavaScript中的try...catch使用小技巧,需要的朋友可以參考下2023-11-11javascript下動態(tài)this與動態(tài)綁定實(shí)例代碼
javascript是一門動態(tài)語言,最明顯就是那個(gè)dynamic this。它一般都是作為函數(shù)調(diào)用者存在。在javascript,所有關(guān)系都可以作為對象的一個(gè)關(guān)聯(lián)數(shù)組元素而存在。2010-01-01JS this關(guān)鍵字在ajax中使用出現(xiàn)問題解決方案
這篇文章主要介紹了JS this關(guān)鍵字在ajax中使用出現(xiàn)問題解決方案,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-07-07js實(shí)現(xiàn)視頻播放時(shí)屏幕顯示水印
這篇文章主要為大家詳細(xì)介紹了js如何實(shí)現(xiàn)視頻播放時(shí)屏幕顯示水印的效果,文中的示例代碼講解詳細(xì),對我們深入掌握js有一定的幫助,感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2023-10-10JavaScript?排他思想的具體實(shí)現(xiàn)
排他思想的算法就是排除掉其他的,本文主要介紹了JavaScript?排他思想的實(shí)現(xiàn),以及介紹了兩個(gè)示例,感興趣的可以了解一下2021-11-11