首頁 > web前端 > 前端問答 > typescript跟es6有什麼差別

typescript跟es6有什麼差別

青灯夜游
發布: 2022-03-23 14:31:35
原創
4054 人瀏覽過

區別:1、TypeScript支援所有原始資料類型,而ES6不支援所有資料型別;2、TypeScript有3個作用域,而ES6有2個作用域;3、TypeScript中模組分為內部模組和外部模組,而ES6中模組分為導入模組和導出模組。

typescript跟es6有什麼差別

本教學操作環境:windows7系統、ECMAScript 6版、Dell G3電腦。

TypeScript

TypeScript是一種由微軟開發的自由和開源的程式語言。它是JavaScript的一個超集,而且本質上向這個語言添加了可選的靜態類型和基於類別的物件導向程式設計。

TypeScript擴充了JavaScript的語法,所以任何現有的JavaScript程式可以不加改變的在TypeScript下運作。 TypeScript是為大型應用之開發而設計,而編譯時它產生 JavaScript 以確保相容性。

TypeScript 支援為已存在的 JavaScript 程式庫添加類型資訊的頭文件,擴展了它對於流行的庫如 jQuery,MongoDB,Node.js和 D3.js 的好處。

TypeScript 的歷史

Anders Hejlsberg開發了 TypeScript。它於2012 年 10 月 1 日首次向公眾推出。經過微軟內部兩年的開發,2013 年發布了新版 TypeScript 0.9。2019 年 4 月 24 日發布了TypeScript 3.4.5。

ES6

ECMAScript (ES) 是由ECMA 國際標準化的腳本語言規範。它的創建是為了標準化 JavaScript。 ES 腳本語言包含許多實現,其中最受歡迎的是JavaScript。開發人員主要將ECMAScript用於萬維網 (WWW)的用戶端腳本。

ECMAScript 標準的第六版是 ECMAScript6 或 ES6,後來更名為ECMAScript 2015。它是對 JavaScript 語言的重大增強,它允許我們為複雜的應用程式編寫程式。它添加了許多旨在簡化大規模軟體開發的功能。最常見的 ES6 網路瀏覽器是Chrome和Firefox。轉譯器將基於 ES6 的程式碼轉換為支援許多瀏覽器的ES5 。 TypeScript 是一個轉譯器。 Grunt、Gulp 和 Babel 是編譯模組的其他一些轉譯器。因此,TypeScript 支援 ES6。

歷史

JavaScript 於 1995 年5 月由Brendan Eich引進。它最初被稱為Mocha,由Netscape創始人Marc Andreessen選擇,後來更名為LiveScript。同時,Sun Microsystems擁有 JavaScript 的商標。 1995年12 月,Netscape 獲得了商標許可,並將其更名為 JavaScript。

在1996 年到1997 年間,Netscape 將 JavaScript 帶到了 ECMA 標準組織,以維護該語言的規範。 1997年6 月,創建了 ECMA 技術委員會 39 (TC39) 以繼續發展該語言,最終發布了ECMA-262 Ed.1。

JavaScript 的第一個標準版本是 ECMAScript 1,於 1997 年6 月發布。一年後,ECMAScript 2 發布了,它只包含了一些小的更改,以保持 JavaScript 的平行 ISO 標準。 1999年12 月,ECMAScript 3 發布,引進了 JavaScript 的許多流行特性。 2009年12 月,ECMAScript 或 ES6 發布,隨後更名為 ECMAScript 2015。

TypeScript和ES6的差異

1、原始資料類型

TypeScript支援所有原始資料類型,ES6不支援所有資料類型。

2、變數作用域

TypeScript有3個作用域:全域作用域、類別作用域、局部作用域。

ES6有2個作用域:全域作用域、局部作用域。

3、模組

在TypeScript中,模組有兩種:內部和外部模組

在ES6中,模組分為導入模組和匯出模組。

【相關推薦:javascript影片教學web前端

以上是typescript跟es6有什麼差別的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板