簡單搭建ES6的環境

来源:https://www.cnblogs.com/toggle/archive/2018/01/07/8232947.html
-Advertisement-
Play Games

一、相容情況 說到ECMAScript6,順便提一下ECMAScript5,先看一下ES5的相容情況。ES5瀏覽器支持情況: Opera 11.60;Internet Explorer 9*;Firefox 4;Safari 5.1**;Chrome 13* IE9不支持嚴格模式 — IE10 添加 ...


一、相容情況

說到ECMAScript6,順便提一下ECMAScript5,先看一下ES5的相容情況。ES5瀏覽器支持情況:
Opera 11.60;Internet Explorer 9*;Firefox 4;Safari 5.1**;Chrome 13
* IE9不支持嚴格模式 — IE10 添加
** Safari 5.1 仍不支持 Function.prototype.bind, 儘管Function.prototype.bind現在已經被
Webkit所支持。

具體ES5、ES6各瀏覽器支持情況可以查看
ECMAScript5:http://kangax.github.io/compat-table/es5/
ECMAScript6:http://kangax.github.io/compat-table/es6/

二、相容方法

針對ES6的相容性問題,很多團隊為此開發出了多種語法解析轉換工具,把ES6語法轉換成ES5。
比較通用的工具方案有babel,traceur,jsx,es6-shim等。
此外,瀏覽器自身也加快速度相容ES6的新特性,其中對ES6新特性最友好的是Chrome和Firefox
瀏覽器。在使用ES6時,先不用引入任何東西,去測試,因為現在瀏覽器已經支持部分ES6功能,有的
不需要轉碼,轉碼反而錯誤。
我們用下麵的代碼去測試瀏覽器是否相容ES6語法const
<script>
const Name = '張三';//使用新增的關鍵字:const聲明常量
alert(Name);
</script>

正常運行,會彈出“張三”,如果報錯我們就知道是瀏覽器出現了相容問題。當瀏覽器不支持
ES6時,再用Babel和Traceur對ES6進行轉碼。

三、使用Babel來相容

使用npm來安裝babel,npm是和Nodejs一起安裝的包管理工具,新版的nodejs已經繼承了npm,我
們只要安裝nodejs即可。在node官網下載尾碼為msi的最新安裝包,下載後找到文件雙擊運行,點擊下
一步安裝即可,期間可以自定義選擇安裝的位置,預設是C:\ProgramFiles\。啟動命令提示符視窗,
輸入“node --version”來檢測當前node的版本,當有版本號顯示說明Node成功安裝。
下麵我們用npm安裝babel,啟動命令提示符視窗並且輸入:npm install babel-core@5,然後回
車,安裝成功後,打開目錄:C:\Users\Administrator\node_modules\babel-core,在這個目錄裡面
我們找到babel的瀏覽器版本browser.js(未壓縮版)和browser.min.js(壓縮版)。把browser.min.js
引入(文件位置的路徑要確保正確)。並且設置第二個script標簽的type為”text/babel”。
<script src="browser.min.js"></script>
<script type="text/babel">
const Name = '張三';
alert(Name);
</script>

四、使用Traceur轉碼器直接插入網頁的方法來轉碼ES6

在網頁頭部載入Traceur庫文件。
<script src="https://google.github.io/traceur-compiler/bin/traceur.js"></script>
<script src="https://google.github.io/traceur-compiler/bin/BrowserSystem.js"></script>
<script src="https://google.github.io/traceur-compiler/src/bootstrap.js"></script>
<script type="module">
const Name = '張三';
alert(Name);
</script>

1.traceur:是由Google出的編譯器,可以將ES5編譯成ES6
2.bootstrap:是一個引導程式(與響應式的bootstrap不同)
3.需要將traceur.js和bootstrap.js下載下來,引入到當前文件中即可
4.最後的script標簽的type屬性的值是module,而不是text/javascript。這是Traceur編譯器識別
ES6代碼的標誌,編譯器會自動將所有type=module的代碼編譯為ES5,然後再交給瀏覽器執行。

五、另外還有Babel轉碼器的其他使用方法,Traceur的命令行轉換方法和Node.js環境的用法,這裡的
方法只是作為一個學習的入門案例,起到拋磚引玉的作用,讓新手們能對ES6的相容問題和轉換工具
有個認識,並沒有覆蓋所有相容方案的介紹,希望大家隨著對ES6越來越深入學習,對轉換工具的掌
握也越來越全面和熟練。


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 1、使用yum install dnsmasq -y 安裝dns(含dns server和dns代理功能) 2、查詢dnsmasq已經安裝成功 [root@localhost ~]# rpm -q dnsmasq dnsmasq-2.48-18.el6_9.x86_64 [root@localhos ...
  • 1、查詢dhcp有沒有被安裝,如下沒有被安裝 [zfp@localhost ~]$ rpm -q dhcppackage dhcp is not installed[zfp@localhost ~]$ 2、查詢yum網路源中有關dhcp的rpm包 [root@localhost zfp]# yum ...
  • 1、執行Python腳本的兩種方式 2、簡述位、位元組的關係 3、簡述ascii、unicode、utf-­‐8、gbk的關係 4、請寫出 “朱銳” 分別用utf-­‐8和gbk編碼所占的位數 5、Pyhton單行註釋和多行註釋分別用什麼? 6、聲明變數註意事項有那些? 7、如有一下變數n1 = 5, ...
  • 在項目中遇到這樣一個問題。 項目地址: https://github.com/ccyinghua/vue-node-mongodb-project/blob/master/07-shoppingCart.md 有一個good商品模型(models/goods.js) 還有一個user用戶模型(mod ...
  • 指定自增類型 [root@node002 conf]# vi /usr/local/mycat/conf/server.xml 每個參數代表的含義: 0:本地文件自增方式。 1:使用mysql自增。 2:使用本地時間戳方式自增。(linux時間) 3:zk分散式方式 4:zookeeper自增方式 ...
  • 前言 在搭建大數據Hadoop相關的環境時候,遇到很多了很多錯誤。我是個喜歡做筆記的人,這些錯誤基本都記載,並且將解決辦法也寫上了。因此寫成博客,希望能夠幫助那些搭建大數據環境的人解決問題。 說明 : 遇到的問題以及相應的解決辦法是對於個人當時的環境,具體因人而異。如果碰到同樣的問題,本博客的方法無 ...
  • 話說昨晚,寫了一篇:講述Sagit.Framework解決:雙向引用導致的IOS記憶體泄漏(上)文章寫到最後時,多了很多莫名奇妙的問題!!!為瞭解決了這些莫名奇妙的問題,我又戰鬥了24小時〜〜〜然後終於解決了問題,原來是IOS的隱藏性Bug,只想恨恨的說一聲fuck~~~ ...
  • createClass本質上是一個工廠函數,extends的方式更加接近最新的ES6規範的class寫法。兩種方式在語法上的差別主要體現在方法的定義和靜態屬性的聲明上。createClass方式的方法定義使用逗號,隔開,因為creatClass本質上是一個函數,傳遞給它的是一個Object;而cla ...
一周排行
    -Advertisement-
    Play Games
  • 示例項目結構 在 Visual Studio 中創建一個 WinForms 應用程式後,項目結構如下所示: MyWinFormsApp/ │ ├───Properties/ │ └───Settings.settings │ ├───bin/ │ ├───Debug/ │ └───Release/ ...
  • [STAThread] 特性用於需要與 COM 組件交互的應用程式,尤其是依賴單線程模型(如 Windows Forms 應用程式)的組件。在 STA 模式下,線程擁有自己的消息迴圈,這對於處理用戶界面和某些 COM 組件是必要的。 [STAThread] static void Main(stri ...
  • 在WinForm中使用全局異常捕獲處理 在WinForm應用程式中,全局異常捕獲是確保程式穩定性的關鍵。通過在Program類的Main方法中設置全局異常處理,可以有效地捕獲並處理未預見的異常,從而避免程式崩潰。 註冊全局異常事件 [STAThread] static void Main() { / ...
  • 前言 給大家推薦一款開源的 Winform 控制項庫,可以幫助我們開發更加美觀、漂亮的 WinForm 界面。 項目介紹 SunnyUI.NET 是一個基於 .NET Framework 4.0+、.NET 6、.NET 7 和 .NET 8 的 WinForm 開源控制項庫,同時也提供了工具類庫、擴展 ...
  • 說明 該文章是屬於OverallAuth2.0系列文章,每周更新一篇該系列文章(從0到1完成系統開發)。 該系統文章,我會儘量說的非常詳細,做到不管新手、老手都能看懂。 說明:OverallAuth2.0 是一個簡單、易懂、功能強大的許可權+可視化流程管理系統。 有興趣的朋友,請關註我吧(*^▽^*) ...
  • 一、下載安裝 1.下載git 必須先下載並安裝git,再TortoiseGit下載安裝 git安裝參考教程:https://blog.csdn.net/mukes/article/details/115693833 2.TortoiseGit下載與安裝 TortoiseGit,Git客戶端,32/6 ...
  • 前言 在項目開發過程中,理解數據結構和演算法如同掌握蓋房子的秘訣。演算法不僅能幫助我們編寫高效、優質的代碼,還能解決項目中遇到的各種難題。 給大家推薦一個支持C#的開源免費、新手友好的數據結構與演算法入門教程:Hello演算法。 項目介紹 《Hello Algo》是一本開源免費、新手友好的數據結構與演算法入門 ...
  • 1.生成單個Proto.bat內容 @rem Copyright 2016, Google Inc. @rem All rights reserved. @rem @rem Redistribution and use in source and binary forms, with or with ...
  • 一:背景 1. 講故事 前段時間有位朋友找到我,說他的窗體程式在客戶這邊出現了卡死,讓我幫忙看下怎麼回事?dump也生成了,既然有dump了那就上 windbg 分析吧。 二:WinDbg 分析 1. 為什麼會卡死 窗體程式的卡死,入口門檻很低,後續往下分析就不一定了,不管怎麼說先用 !clrsta ...
  • 前言 人工智慧時代,人臉識別技術已成為安全驗證、身份識別和用戶交互的關鍵工具。 給大家推薦一款.NET 開源提供了強大的人臉識別 API,工具不僅易於集成,還具備高效處理能力。 本文將介紹一款如何利用這些API,為我們的項目添加智能識別的亮點。 項目介紹 GitHub 上擁有 1.2k 星標的 C# ...