摘要:的新特性哪些適合使用我們參考使用進行開發(fā)的思考文章推薦的新特性,僅使用三星的。另外推薦閱讀探秘系列的新特性是否通過轉(zhuǎn)換后還有兼容問題團隊中又同學(xué)正在驗證,我們驗證的環(huán)境是,我們最終會使用三星特性加上兼容性的。
最近項目中的一個模塊正式引入的ES6,由于是引入新技術(shù),也遇到了一些問題,下面分享下整個引入流程
為什么要引入ES6最近在看一些前端解決方案的文章,ES6越來越多的出現(xiàn)在前端方案中。
ES6由于瀏覽器不支持,在使用上也是和CoffeeScript和TypeScript一樣,都需要compile-to-JS。
理由一:
符合未來趨勢,angular2就是使用TypeScript實現(xiàn);
react native 也是可以直接使用es6的語法;
理由二:
提高開發(fā)效率(待考證);
理由三:
減少代碼量、提高可讀性等
但我覺得不僅僅如此,應(yīng)該會有更多優(yōu)勢。所以需要親自驗證。
引入前考慮最多的事情從個人的角度,趨勢這個東西說不準(zhǔn),減少代碼量、提高可讀性等這些其實都可以通過規(guī)范來完成。
我個人最看重的是效率這塊,是否能夠真正的提高團隊開發(fā)效率。
另外在一片文章中看到說facebook.com 都使用了ES6 + babel complile,我心里也安穩(wěn)了一些。
考慮的第二點就是是否會給整個系統(tǒng)引入技術(shù)債務(wù),由于這個是新技術(shù)的引入,和之前框架沒有任何重疊,而且引入也是選擇性的(提供一種可用的環(huán)境)。如果未來有較大的升級,我們可以修改compile-to-JS做適配和轉(zhuǎn)換。
最后一個問題是我們項目使用的不是grunt這種,有直接的解決方案,引入可能會有風(fēng)險。不過慶幸的是,我們發(fā)現(xiàn)我們使用的edp已經(jīng)支持了。其實我們開始已經(jīng)想好了如果不支持,自己會擴展一些插件去支持。
技術(shù)方案ES6 + babel
需要解決的問題開發(fā)環(huán)境下的瀏覽器不支持ES6?
使用babel轉(zhuǎn)換的代碼,調(diào)試不方便?
線上環(huán)境的代碼打包編譯怎么處理?
ES6的新特性哪些適合使用?
ES6的新特性是否通過babel轉(zhuǎn)換后還有兼容問題?
開發(fā)效率是否會有提高?
編譯器高亮支持?
下面挨個解決問題想到一句話
你可以坐以待斃,也可以立刻動手解決問題,解決一個再解決一個,解決了所有問題,你就活下來可以回家了
來自《火星救援》
開發(fā)環(huán)境下的瀏覽器不支持ES6?
這個容易,使用babel。
使用babel轉(zhuǎn)換的代碼,調(diào)試不方便?
確定了sourceMap的方式解決,但是開始沒有認真看babel文檔,繞了個圈子,最后發(fā)現(xiàn)babel有個屬性
sourceMaps:both filename: pathname.replace(/.(w+)$/, ".raw.$1")
傳入這個參數(shù)sourceMaps傳入表示啟用;
filename是編譯前對應(yīng)的文件,這里必須給一個和處理的文件名不一樣的
babel.transform(code, options)
線上環(huán)境的代碼打包編譯怎么處理?
在構(gòu)建的流程中,加入一個babel-processor的流程即可,加入的時機需要是在模塊壓縮合并前,其實就是越早越好。
ES6的新特性哪些適合使用?
我們參考
使用ES6進行開發(fā)的思考
arrows ★★★
classes ★★★
enhanced object literals ★★★
template strings ★★★
destructuring ★★
default + rest + spread ★★★
let + const ★★★
iterators + for..of ★★
generators ★
unicode ☆
modules ★★
module loaders ☆
map + set + weakmap + weakset ★★
proxies ☆
symbols ★
subclassable built-ins ☆
promises ★★★
math + number + string + array + object APIs ★★★
binary and octal literals ★
reflect api ☆
tail calls ★★
文章推薦的新特性,僅使用三星的。
另外推薦閱讀探秘ES6 系列
ES6的新特性是否通過babel轉(zhuǎn)換后還有兼容問題?
團隊中又同學(xué)正在驗證,我們驗證的環(huán)境是IE9+,ff,chrome,我們最終會使用三星特性加上兼容性ok的。
開發(fā)效率是否會有提高?
后面會通過做一個小的新需求,或者重構(gòu)一個小模塊去驗證。
編譯器高亮支持?
sublime Text 下面
https://github.com/babel/babel-sublime
或者
https://github.com/voronianski/oceanic-next-color-scheme
其實問題就這么多,比想象中簡單許多,未來可能還有坑,但是至少我們開始嘗試了。
紅利語法有問題時,編譯報錯——語法檢查
面向未來——未來很多源碼都是預(yù)編譯類型
開闊前端思路
能讀懂以后牛逼框架的源碼, angular2 使用typescript
微信公眾號 博客地址http://tangguangyao.github.io/
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/91563.html
摘要:異步編程前異步編程的解決方式回調(diào)函數(shù)事件監(jiān)聽發(fā)布訂閱自定義提供了原生的對象,統(tǒng)一了用法和標(biāo)準(zhǔn)。如果不設(shè)置回調(diào)函數(shù),或在中再次拋出錯誤。函數(shù)內(nèi)部語句返回的值,會成為方法回調(diào)函數(shù)的參數(shù)。 ECMAScript 6.0于2015 年 6 月正式發(fā)布了,成為JavaScript 語言的下一代標(biāo)準(zhǔn)。ES6增加的語言特性解決了哪些問題,會給開發(fā)者哪些便利,是本文主要探討的問題。 增加了對unico...
摘要:常見模塊化方案是由社區(qū)提出的模塊化方案中的一種,遵循了這套方案。是模塊化規(guī)范中的一種,遵循了這套規(guī)范。中的模塊化能力由兩個命令構(gòu)成和,命令用于規(guī)定模塊的對外接口,命令用于輸入其他模塊提供的功能。 為什么需要模塊化 在ES6出現(xiàn)之前,JS語言本身并沒有提供模塊化能力,這為開發(fā)帶來了一些問題,其中最重要的兩個問題應(yīng)當(dāng)是全局污染和依賴管理混亂。 // file a.js var name =...
摘要:我們在之前文章與面向?qū)ο缶幊讨校f到了目前大部分框架和庫,都采用了面向?qū)ο蠓绞骄幊獭D敲淳唧w是怎么樣應(yīng)用的呢面向?qū)ο缶幊蹋畹湫秃妥罨A(chǔ)的作用就是封裝,封裝的好處就是代碼的能夠復(fù)用,模塊化,進行項目和文件的組織。模塊化在中的應(yīng)用。 我們在之前文章《ES6 class與面向?qū)ο缶幊獭分校f到了目前大部分框架和庫,都采用了面向?qū)ο蠓绞骄幊獭D敲淳唧w是怎么樣應(yīng)用的呢?面向?qū)ο缶幊蹋畹湫秃妥?..
摘要:我們可以認為,宏任務(wù)中還有微任務(wù)這里不再多做解釋可能會執(zhí)行的代碼包括腳本模塊和函數(shù)體。聲明聲明永遠作用于腳本模塊和函數(shù)體這個級別,在預(yù)處理階段,不關(guān)心賦值的部分,只管在當(dāng)前作用域聲明這個變量。 相信很多人最開始時都有過這樣的疑問假如我的項目目錄下有一個 index.html, index.js 于是我像這樣寫 在瀏覽器之間打開index.html,發(fā)現(xiàn)showImg(https://...
摘要:要求模塊編寫必須在真正的代碼之外套上一層規(guī)定的代碼包裝,樣子看起來是這樣的模塊代碼通過傳遞一個簽名為的回調(diào)函數(shù)給函數(shù),就可以把需要注入的變量和函數(shù)注入到模塊代碼內(nèi)。 之前寫的文章急速Js全棧教程得到了不錯的閱讀量,霸屏掘金頭條3天,點贊過千,閱讀近萬,甚至還有人在評論區(qū)打廣告,可見也是一個小小的生態(tài)了;)。看來和JS全棧有關(guān)的內(nèi)容,還是有人頗有興趣的。 showImg(https://...
閱讀 2394·2021-10-09 09:41
閱讀 3192·2021-09-26 09:46
閱讀 842·2021-09-03 10:34
閱讀 3173·2021-08-11 11:22
閱讀 3378·2019-08-30 14:12
閱讀 720·2019-08-26 11:34
閱讀 3352·2019-08-26 11:00
閱讀 1781·2019-08-26 10:26