Angular2如何使用第三方類庫(如:jQuery)

如何導入第三方類庫?

類庫都是經過 npm 進行安裝的,好比:node

npm install --save jquery

會將所須要的類庫文件下載至 node_modules/jquery 當中;因此還須要將類庫與Angular進行關聯。jquery

打開 src/.angular-cli.json 找到 apps/scripts 節點,添加相應的類庫至此。npm

"scripts": [
    "../node_modules/jquery/dist/jquery.js"
]

如何在Angular中使用呢?

首先,第一關鍵點TypeScript是編譯型,既然是編譯型,那麼你在代碼中出現的任何變量、類、函數都是必需要存在,不然編譯器就會在編譯時報錯。編程

但,問題來了,如今的JavaScript世界中已經有那麼多現成的第三方庫,難道說都不能用了?非也!json

TypeScript一開始就照顧這些了,因此就會有一個叫.d.ts的聲明文件。MS固然不會讓你去編寫這一個文件,因此就有一個叫 definitelytyped 網站,TA聚集了不少現成類庫的第三方.d.ts的聲明文件提供咱們下載。api

方法一

固然是使用最正規軍了,用命令安裝jQuery的聲明文件。app

npm install -D @types/jquery 最後,你能夠在代碼中這麼使用:函數

import * as $ from 'jquery';網站

$('body').addClass(''); 完美的智能提示,若是你在VS CODE下的話。.net

方法二

對於一些並未提供 .d.ts 聲明文件的類庫,咱們怎麼辦?那固然只能本身寫了。

什麼?本身寫?很困難吧!很複雜吧!

沒那麼一回事,聲明文件實際上是對一些類庫接口的描述,如下是我截取一段jQuery聲明文件的部分代碼

interface JQueryStatic { /** * 去掉字符串首尾空格 * * @param str 字符串 * @see {@link https://api.jquery.com/jQuery.trim/} */ trim(str: string): string; }

declare var $: JQueryStatic; 我還特地譯成中文,這裏的含量不多,最關鍵的就是 declare 它就是把一個變量 $ 定義成類型 JQueryStatic (仍是個接口)。

這樣,TS編譯器在遇到 $ 時會去找該類型,而且你的代碼裏面不能出現 $.time1() 之類的,由於你的接口,只有一個 $.trim()。

等等,jQuery幾十個接口,我都要這麼寫嗎? NO!!!固然不是,除非你想寫一個又漂亮、又好看、又是中文、又是完美智能提示的聲明文件的話。

不然,你那就拿 any 類型吧,TA就是萬能貨。你不須要寫一個很複雜的聲明文件,只須要:

declare var $: any; 簡單粗暴有效!

結論

哎~實際上是因羣裏天天均可以看到一句【怎麼使用jQuery】;雖然最簡單的結果只須要一句話 declare var $: any;,但我仍是囉裏吧嗦將了一大堆,可不把來龍去脈將清楚,我煩~。

另,此解只是拋磚引玉,在不少類庫中都是通用的辦法。但我建議仍是找一些Angular2類庫來使用,由於如何更有效的管理JavaScript運行,是一門學問。

但願此篇對你的幫助,快樂編程!

相關文章
相關標籤/搜索