安卓手機為什麼不支持es6
⑴ 怎麼使用polyfill解決華為手機兼容VUE的問題
IE瀏覽器沒有內置Promise對象。不僅如此,幾乎所有的ES6新增的方法在IE都不能用,比如Array.from。因為babel只會轉譯語法,並不會新增方法。
此時你需要babel Polyfill
⑵ 移動端使用es6語法需要編譯嗎
然而, Babel默認只轉換新的JavaScript句法(syntax),而不轉換新的API,比如Iterator、Generator、Set、Maps、Proxy、Reflect、Symbol、Promise等全局對象,以及一些定義在全局對象上的方法(比如Object.assign)都不會轉碼。而且像import和export這兩個命令現在在任何瀏覽器中都是不支持的, 同時babel也無法將其轉換為瀏覽器支持的ES5, 原因在於:
babel只是個翻譯,假設a.js 里 import 了 b.js, 對a.js進行轉碼,只是翻譯了a.js,並不會把b.js的內容給讀取合並進來, 如果想在最終的某一個js里,包含 a.js,b.js 的代碼,那就需要用到打包工具
所以我在這里講解一下如何使用webpack工具將帶有import和export語法的JS文件, 通過打包工具生成所有瀏覽器都支持的單個JS文件.
1. 下載node.js和webpack
Node.js是一個基於Chrome JavaScript運行時建立的平台, 用於方便地搭建響應速度快、易於擴展的網路應用。可以說就是伺服器端的JS. webpack是一個打包工具, 而它是依賴於node.js運行的.
下載node.js可以通過官網:
具體的安裝步驟網上可以搜到很多, 這里不再贅述. 安裝完畢後打開node.js自帶的命令行工具
這里寫圖片描述
然後輸入如下命令全局安裝webpack工具
npm install -g webpack
接著通過命令行工具定位到你的工程文件的根目錄下, 再次安裝webpack到你的工程中
npm install webpack
2. 編寫webpack.config.js文件
在根目錄下創建webpack.config.js, 這個文件是用來描述一些要使用webpack工具進行打包的配置信息, 文件內容如下:
這里寫圖片描述
通過該文件可以使用webpack打包工具, webpack會從import.js進入, 對該文件中的內容進行編譯並打包, 最終會在dist目錄下生成打包好的文件bundle.js, 編譯打包過程中用到的工具在mole對象的loaders中聲明, 這里使用了babel-loader來對JS文件進行編譯(包括從ES6轉換為ES5以及打包)
3. 創建import.js
創建一個import.js, 內容如下:
這里寫圖片描述
在該文件中通過ES6語法import從export.js中引入firstName和lastName變數. 並且通過console.log將引入的兩個變數列印到控制台.
4. 創建export.js
這里寫圖片描述
在該文件中通過ES6語法export將文件中的幾個變數作為模塊輸出給別的文件引用.
5. 創建HTML文件
在HTML文件中直接將webpack最終打包生成的bundle.js文件引入即可, 因為通過webpack工具已經將export.js和import.js的所有內容都打包到一個文件bundle.js中了, 因此在HTML文件中引入該文件即可以將兩個JS文件中的代碼都執行.
這里寫圖片描述
6. 配置.babelrc文件
在工程文件的根目錄下創建一個.babelrc文件(注意前面有個點), 這個文件是用來描述我要根據什麼樣的規則、或者是將JS文件編譯成什麼版本的文件(比如說ES5). 該文件的內容如下:
這里寫圖片描述
7. 下載相關依賴模塊
方式1: 可以像下面這樣, 直接在項目根目錄下創建一個package.json文件, 並且在文件中指定devDependencies對象, 在該對象中寫上我編譯及打包中所要使用到的依賴模塊, 圖片中的webpack就是用於打包的工具, 而其他的以babel開頭的選項都是編譯JS文件並打包所需要用到的依賴模塊.
這里寫圖片描述
創建好package.json文件後, 在命令行中輸入
npm install
npm工具就會根據該文件中devDependencies選項下載對應的依賴模塊.
方式2(推薦): Ctrl+R打開運行, 然後輸入cmd打開命令行工具, 通過命令行工具一個個安裝, 這樣可以直接通過npm去下載依賴模塊最新的穩定的版本, 同時也不需要自己去記這些模塊的版本號
npm install babelnpm install babel-clinpm install babel-corenpm install babel-loadernpm install babel-preset-es2015
8. 使用 webpack打包
使用命令行工具定位到項目的根目錄下, 然後輸入如下指令
webpack
等待一會兒就會發現工程文件的目錄下多了一個dist文件夾, 裡面放著的就是打包好了的bundle.js文件, 在HTML文件中通過下面的代碼引入js文件
然後在瀏覽器上運行html文件, 使用F12打開開發者工具, 就可以看到console選項中輸出兩行記錄」Micheal」, 「Jackson」
⑶ webengineview支持es6嗎
Android低版本自帶webengineview不支持es6
在手機上運行,需要安卓版本6.0以上才支持es6。只需在項目目錄上點右鍵,選擇引入語法框架,選擇es6。自帶的瀏覽器不支持es6。
使用前端打包工具,如grunt,webpack等,將ES6代碼自動編譯為ES5。處理方案是更換瀏覽器內核,備選項有兩個,X5和crosswalk,看技術文章說crosswalk體積比較大,果斷拋棄,使用了與微信QQ共享內核的X5。
⑷ 微信哪個版本自帶瀏覽器支持es6
然而, Babel默認只轉換新的JavaScript句法(syntax),而不轉換新的API,比如Iterator、Generator、Set、Maps、Proxy、Reflect、Symbol、Promise等全局對象,以及一些定義在全局對象上的方法(比如Object.assign)都不會轉碼。而且像import和exp...
⑸ es6是什麼
ES6, 全稱 ECMAScript 6.0 ,是 JavaScript 的下一個版本標准,2015.06 發版。
ES6 主要是為了解決 ES5 的先天不足,比如 JavaScript 里並沒有類的概念,但是目前瀏覽器的 JavaScript 是 ES5 版本,大多數高版本的瀏覽器也支持 ES6,不過只實現了 ES6 的部分特性和功能。
⑹ Vscode的自動錯誤提示不支持ES6,求幫助
我之前也遇到這個問題,具體你可以google,關鍵字是vscode property
declaration,然後可以在github上看到相關的討論,vscode開發人員給出的辦法是禁用vscode自帶的語法檢查,使用eslint,但是他沒有給出具體的操作辦法
啊,剛才自己看了一下一樓給的答案里的那個鏈接,裡面就有
Disable Syntax Validation when using non ES6 constructs
JavaScript Linters (ESLint, JSHint)
這兩個部分,照做即可
⑺ android es6 是不是有好多手機瀏覽器不兼容
12306新app的兼容問題,我試的是12306官網最新1.2.05版(官網公告8.1號強制使用的版本。目前只能用這新版,舊版已經被強制無法使用,提示升級新版)。。 試的結果: 我的七彩虹平板(4.4.2系統),能安裝,但打開後大多數時候是空白無顯示(偶爾也能有界面,但無法登錄); 家裡另一台聯想A3000平板,華為手機榮耀3C(都是4.2系統版本),OK 舊手機中興V889D(2.3.6系統)OK。 所以可以確定是這個新app與安卓4.4及以上版本有兼容問題。