欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

TypeScript對于Duck類型和模塊命名空間應(yīng)用

 更新時間:2022年08月18日 14:10:10   作者:黎燃黎燃???????  
這篇文章主要介紹了TypeScript對于Duck類型和模塊命名空間應(yīng)用,Duck類型是一種動態(tài)類型和多態(tài)形式,在duck類型中,重點是對象的行為可以做什么,而不是對象所屬的類型

一.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類型中,重點是對象的行為可以做什么,而不是對象所屬的類型。
例如,在不使用duck類型的語言中,我們可以編寫一個函數(shù),該函數(shù)接受“duck”類型的對象并調(diào)用其“walk”和“call”方法。
在使用duck類型的語言中,這樣的函數(shù)可以接受任何類型的對象并調(diào)用其“go”和“call”方法。
如果這些需要調(diào)用的方法不存在,則會引發(fā)運行時錯誤。具有這種正確的“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})  
 
// 錯誤 
var newPoint2 = addPoints({x:1},{x:4,y:3})

二.TypeScript 命名空間

名稱空間最明確的目的之一是解決重復(fù)名稱的問題。
假設(shè)班上有兩個叫小明的學(xué)生。為了清楚地區(qū)分他們,我們必須使用他們名字之外的一些附加信息,例如他們的姓氏(王曉明、李曉明)或他們父母的名字。
命名空間定義標(biāo)識符的可見范圍。一個標(biāo)識符可以在多個名稱空間中定義,它在不同名稱空間中的含義是無關(guān)的。這樣,任何標(biāo)識符都可以在新名稱空間中定義,并且它們不會與任何現(xiàn)有標(biāo)識符沖突,因為現(xiàn)有定義在其他名稱空間中。

typescript中的命名空間由命名空間定義。語法格式如下:

namespace SomeNameSpaceName { 
   export interface ISomeInterfaceName {      }  
   export class SomeClassName {      }  
}

上面定義了一個名稱空間somenamespacename。
如果我們需要在外部調(diào)用somenamespacename中的類和接口,我們需要向類和接口添加export關(guān)鍵字。

要調(diào)用另一個命名空間,語法格式為:

SomeNameSpaceName.SomeClassName;

如果命名空間位于單獨的typescript文件中,則應(yīng)使用三個斜杠///引用它。

語法格式如下:

/// <reference path = "SomeFileName.ts" />
namespace Drawing { 
    export interface IShape { 
        draw(); 
    }
}

名稱空間支持嵌套,也就是說,可以在另一個名稱空間中定義名稱空間。

namespace Runoob { 
   export namespace invoiceApp { 
      export class Invoice { 
         public calculateDiscount(price: number) {
            return price * .40;
         }
      }
   }
}

三.TypeScript 模塊

typescript模塊設(shè)計有可替換的組織代碼。
模塊在其自己的范圍內(nèi)執(zhí)行,而不是在全局范圍內(nèi),這意味著模塊中定義的變量、函數(shù)和類在模塊外部不可見,除非它們使用導(dǎo)出顯式導(dǎo)出。
同樣,我們必須導(dǎo)入其他模塊通過導(dǎo)入導(dǎo)出的變量、函數(shù)、類等。
這兩個模塊之間的關(guān)系是通過在文件級使用導(dǎo)入和導(dǎo)出來建立的。
模塊使用模塊加載器導(dǎo)入其他模塊。在運行時,模塊加載器的功能是在執(zhí)行模塊代碼之前查找并執(zhí)行模塊的所有依賴項。最常見的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)用庫的類和方法,但不能使用類型腳本功能,如類型檢查。
為了解決這個問題,我們需要刪除這些庫中的函數(shù)和方法體,只保留導(dǎo)出的類型聲明。
相反,將生成描述JavaScript庫和模塊信息的聲明文件。
通過引用此聲明文件,可以借用typescript的各種功能來使用庫文件。

如果我們想使用第三方庫,比如jQuery,我們通常會得到一個ID為foo的元素,如下所示:

$('#foo');
// 或
jQuery('#foo');

但在typescript中,我們不知道$jQuery是什么:

jQuery('#foo');

// index.ts(1,1): error TS2304: Cannot find name 'jQuery'.

此時,我們需要使用declare關(guān)鍵字定義其類型,以幫助typescript判斷傳入的參數(shù)類型是否正確:

declare var jQuery: (selector: string) => any;

jQuery('#foo');

declare定義的類型僅用于編譯時的檢查,并將從編譯結(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)思想實現(xiàn)的數(shù)組去重功能【案例】

    JS基于開關(guān)思想實現(xiàn)的數(shù)組去重功能【案例】

    這篇文章主要介紹了JS基于開關(guān)思想實現(xiàn)的數(shù)組去重功能,簡單分析了開關(guān)思想的原理,并結(jié)合具體實例形式分析了javascript基于開關(guān)思想實現(xiàn)數(shù)組去重相關(guān)操作技巧,需要的朋友可以參考下
    2019-02-02
  • 百度判斷手機(jī)終端并自動跳轉(zhuǎn)js代碼及使用實例

    百度判斷手機(jī)終端并自動跳轉(zhuǎn)js代碼及使用實例

    這篇文章主要介紹了百度判斷手機(jī)終端并自動跳轉(zhuǎn)js代碼及使用實例,需要的朋友可以參考下
    2014-06-06
  • js判斷瀏覽器是否支持html5

    js判斷瀏覽器是否支持html5

    這篇文章主要介紹了如何使用js判斷瀏覽器是否支持html5,需要的朋友可以參考下
    2014-08-08
  • js實現(xiàn)的文字橫向無間斷滾動

    js實現(xiàn)的文字橫向無間斷滾動

    要實現(xiàn)這樣一個功能,文字在某塊區(qū)域內(nèi)橫向無間隙滾動。
    2010-12-12
  • 深入理解JavaScript中的for循環(huán)

    深入理解JavaScript中的for循環(huán)

    這篇文章主要給大家深入的介紹了JavaScript中的for循環(huán),其中包括ES5中的三種for循環(huán),分別是簡單for循環(huán)、for-in以及forEach,另外還詳細(xì)介紹了ES6新增的一種循環(huán):for-of ,有需要的朋友可以參考借鑒,下面來一起看看吧。
    2017-02-02
  • 聊聊JavaScript中的try...catch使用小技巧

    聊聊JavaScript中的try...catch使用小技巧

    作為一名web前端工程師,JavaScript中的try...catch是我們常用的特性之一,用于處理代碼中可能出現(xiàn)的錯誤,本文小編將和大家一起聊聊JavaScript中的try...catch使用小技巧,需要的朋友可以參考下
    2023-11-11
  • javascript下動態(tài)this與動態(tài)綁定實例代碼

    javascript下動態(tài)this與動態(tài)綁定實例代碼

    javascript是一門動態(tài)語言,最明顯就是那個dynamic this。它一般都是作為函數(shù)調(diào)用者存在。在javascript,所有關(guān)系都可以作為對象的一個關(guān)聯(lián)數(shù)組元素而存在。
    2010-01-01
  • JS this關(guān)鍵字在ajax中使用出現(xiàn)問題解決方案

    JS this關(guān)鍵字在ajax中使用出現(xiàn)問題解決方案

    這篇文章主要介紹了JS this關(guān)鍵字在ajax中使用出現(xiàn)問題解決方案,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2020-07-07
  • js實現(xiàn)視頻播放時屏幕顯示水印

    js實現(xiàn)視頻播放時屏幕顯示水印

    這篇文章主要為大家詳細(xì)介紹了js如何實現(xiàn)視頻播放時屏幕顯示水印的效果,文中的示例代碼講解詳細(xì),對我們深入掌握js有一定的幫助,感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下
    2023-10-10
  • JavaScript?排他思想的具體實現(xiàn)

    JavaScript?排他思想的具體實現(xiàn)

    排他思想的算法就是排除掉其他的,本文主要介紹了JavaScript?排他思想的實現(xiàn),以及介紹了兩個示例,感興趣的可以了解一下
    2021-11-11

最新評論