gulp-babel使用

来源:http://www.cnblogs.com/w-jinfeng/archive/2016/05/17/5501902.html
-Advertisement-
Play Games

各大瀏覽器廠商對es2015功能支持不完全,等到全部支持會等很長時間,如果現在使用es2015,可以選擇babel一個將ES6/ES7寫的代碼轉換為ES5代碼的編譯器. 我們選擇使用gulp自動化編譯生成es5代碼. 假設你已經安裝過了nodejs. 配置開發環境: 1. 建立工程目錄: 2. 新建 ...


各大瀏覽器廠商對es2015功能支持不完全,等到全部支持會等很長時間,如果現在使用es2015,可以選擇babel一個將ES6/ES7寫的代碼轉換為ES5代碼的編譯器.

我們選擇使用gulp自動化編譯生成es5代碼.

假設你已經安裝過了nodejs.

配置開發環境:

1. 建立工程目錄:  

$mkdir test && cd test

 

2. 新建工程配置文件package.json 

$npm init

3. 安裝gulp工具

$npm install --save-dev gulp gulp-babel gulp-concat gulp-sourcemaps babel-preset-es2015

 

4. 新建gulp配置文件

$vim gulpfile.js

 

寫入代碼gulpfile.js:

const gulp = require("gulp");

const sourcemaps = require("gulp-sourcemaps");

const babel = require("gulp-babel");

const concat = require("gulp-concat");

 

gulp.task('default', () =>

    gulp.src('src/**/*.js')

        .pipe(babel({

            presets: 'es2015'

        }))

        .pipe(gulp.dest('dist'))

);

 

//生成sourcemaps

 

gulp.task('all', () =>

    gulp.src('src/**/*.js')

        .pipe(sourcemaps.init())

        .pipe(babel({

            presets: 'es2015'

        }))

        .pipe(concat('all.js'))

        .pipe(sourcemaps.write('.'))

        .pipe(gulp.dest('dist'))

);
View Code 

 

5. 測試是否配置成功

mkdir src && cd src && vim app.js

 

寫入代碼:

function f() { 

    let x;

    {

      // okay, block scoped name

      const x = "sneaky";

      // error, const

      //x = "foo";

console.log(x);

    }

    // okay, declared with `let`

    x = "bar";

    // error, already declared in block

    //let x = "inner";

    console.log(x);

}

 

f();
View Code

 

6.執行

$gulp

 

會自動生成dest目錄,包含app.js文件,是轉化過的js.恭喜你已經學會!

 


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

-Advertisement-
Play Games
更多相關文章
  • 今天用仿站工具下載了一個比較不錯的html5網站,但在本地就無法打開,打開的網頁是個白板。檢查元素髮現沒有body元素,本地代碼明明有boby,瀏覽器中卻沒有,估計是js在搗鬼。 挨個註銷引用的js,發現被註銷後,能顯示一點網頁內容。 分析這個js,先是整理格式,發現有一個註釋// index.js... ...
  • node+express+jade+mongodb搭建了一套個人博客,我來總結下這幾個家伙的使用感受吧! 【node】 成熟插件庫眾多,真的是只有你想不到,沒有它做不到的。而且對於有前端JS基礎的童鞋來說,上手特別容易。當然要是對http有所瞭解的童鞋就更好了。 【express】 簡單粗暴、易上手 ...
  • 今天工作用到了select,想要給option添加click點擊事件,可是卻沒有任何效果,百度了才發現,原來竟然是不支持呀! 眾所周知(其實我才知道哎),在IE里, select的option是不支持onclick事件的, 而在FF 和 OPERA 里, option 是支持onclick事件的. ...
  • 方法一: 方法二: sh function GetRequest(url) { url = url == null ? window.location.href : url;//獲取url中"?"符後的字串 var theRequest = new Object(); if (url.indexOf ...
  • 就一個小功能,最近做網站用到,怕忘了就記了下來。 ...
  • CSS border用於設置HTML元素(如div)的邊框,包括邊框的寬度、顏色和樣式。本文章向碼農介紹CSS border邊框屬性詳細內容,感興趣的碼農可以參考一下。 CSS 邊框即CSS border-border邊框樣式顏色、邊框樣式、邊框寬度的語法結構與應用案例教程篇 一、CSS邊框基礎知識 ...
  • ...
  • 最近心血來潮要開始玩博客了,剛好也在看數組這塊內容,第一篇就只好拿數組開刀了,自己總結的,有什麼不對的地方還請批評指正,還有什麼沒寫到的方面也可以提出來我進行完善,謝謝~~ 首先,大概說說數組的基本用法。 數組,即Array類型,是開發中最常用的類型之一,javascript中的數組和其他語言最大的 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...