Vue學習之Babel配置(十六)

来源:https://www.cnblogs.com/21-forever/archive/2019/07/03/11128435.html
-Advertisement-
Play Games

一、Babel: (官網:https://www.babeljs.cn/docs/) 1、Babel 是一個 JavaScript 編譯器; 2、Babel 是一個工具鏈,主要用於將 ECMAScript 2015+ 版本的代碼轉換為向後相容的 JavaScript 語法,以便能夠運行在當前和舊版本 ...


一、Babel:  (官網:https://www.babeljs.cn/docs/)

 1、Babel 是一個 JavaScript 編譯器;

2、Babel 是一個工具鏈,主要用於將 ECMAScript 2015+ 版本的代碼轉換為向後相容的 JavaScript 語法,以便能夠運行在當前和舊版本的瀏覽器或其他環境中。

3、 Babel的作用:

  ①、語法轉換

  ②、通過 Polyfill 方式在目標環境中添加缺失的特性 (通過 @babel/polyfill 模塊)

  ③、源碼轉換 (codemods)

二、Babel配置思路:

  在webpack中,預設只能處理 一部分ES6的新語法,一些更高級的ES6或者ES7 語法,webpack是處理不了的;這時候,就需要藉助於第三方的 loader ,來幫助webpack 處理這些高級的語法;當第三方loader 把高級語法轉為低級語法之後,會把結果交給 webpack 去打包到bundle.js中;

 通過Babel ,可以幫我們將高級的語法轉換為 低級的語法:

1、在webpack 中,可以運行如下兩套命令,安裝兩套包,去安裝babel 相關的loader功能:

①、第一套包:

  

cnpm i babel-core babel-loader babel-plugin-transform-runtime -D

②、第二套包:

cnpm i babel-preset-env babel-preset-stage-0 -D

2、打開 webpack 的配置文件,在module節點下的rules 數組中,添加一個新的匹配規則:

①、

{ test :/\.js$/, use :'babel-loader',  exclude:/node_modules/ }

②、註意:在配置babel 的loader 規則的時候,必須把node_modules目錄,通過 exclude選項排除掉:原因有倆:

I、如果不排除 node_modules ,則babel 會把 node_modules 中所有的第三方JS文件,都打包編譯,這樣,會非常消耗CPU,同時,打包速度非常慢;

II、哪怕,最終,babel 把所有的node_modules 中的JS 轉換完畢了,但是,項目也無法正常運行。

3、在項目的 根目錄中,新建一個叫做:.babelrc的Babel 配置文件,這個配置文件,屬於JSON 格式,所以,在寫.babelrc 配置的時候,必須符合JSON語法規範:不能寫註釋,字元串必須用雙引號;

①、在.babelrc 寫下的配置:大家可以把 preset 翻譯成 【語法】 的意思:

{
    "presets": [" env","stage-0"],
    "plugins": ["transform-runtime"]
}

4、目前,我們安裝的  babel-preset-env 是比較新的es語法,之前,我們安裝的是babel-preset-es2015,現在,出了一個更新的語法插件,叫做 babel-preset-env ,它包含了所有的 和es **相關的語法。

 


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

-Advertisement-
Play Games
更多相關文章
  • 收藏常用的蘋果開發站點 www.apple-dev.cn www.cocoachina.com ...
  • sub和sup元素會輕微地增大行高。 幸好,用一點CSS就可以修複這個問題。 來自Nicolas Gallagher和Jonathan Neal的normalize.css(http://necolas.github.com/normalize.css/)。 他們借用了https://gist.gi ...
  • 一、子元素選擇器 1.定義:找到指定標簽中所有特定的直接子元素,然後設置屬性 2.格式: 3.釋義:先找到叫做“標簽名稱1”的標簽,然後在這個標簽中查找所有直接子元素名稱叫做“標簽名稱2”的元素 : (1)子元素選擇器智慧查找兒子,不會查找孫子,重孫子等等 (2)子元素選擇器之間需要用“>”符號相連 ...
  • 表格的隔行變色樣式,checkbox的全選+反選功能實現商品購物車頁面的結算功能。 ...
  • [2019.07.03 學習筆記2] 1.定義列表,沒有項目符號,type無法起作用。 2.自定義列表以<dl>標簽開始,自定義列表項始於<dt>標簽,每個自定義列表項的定義始於<dd>。 ...
  • [2019.07.03 學習筆記1] 1.定義有序列表,有順序。 2.預設情況下採用數字進行標記,有序列表始於<ol>標簽,每個列表項始於<li>。 1 <!DOCTYPE html> 2 <html lang="en"> 3 <head> 4 <meta charset="UTF-8"> 5 <t ...
  • 傳統diff 通過迴圈遞歸對節點的依次對比,複雜度是O(n3) react diff react對傳統diff進行了優化,將複雜度降為O(n) react基於這幾個前提對diff進行了優化: 忽略跨層級操作,因為DOM節點跨層級操作很少。 不同類的組件,則會生成不同的樹形結構,相同類的組件,會生成相 ...
  • 一、包的查找規則: 1、在項目根目錄中找有沒有 node_modules 的文件夾; 2、在 node_modules 中根據包名,找對應的vue 文件夾; 3、在vue 文件夾中,找 一個叫做 package.json的包配置文件; 4、在package.json文件中,查找一個main 屬性【m ...
一周排行
    -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# ...