簡單搭建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
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...