亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Vue中?引入使用?babel-polyfill?兼容低版本瀏覽器的方法

 更新時間:2023年02月20日 14:38:01   作者:明天也要努力  
最近在項目中使用 webpack 打包后升級,用戶反饋使用瀏覽器(chrome 45)訪問白屏。經(jīng)過排查發(fā)現(xiàn):由于 chrome 45 無法兼容 ES6 語法導(dǎo)致的,接下來給大家介紹下Vue中?引入使用?babel-polyfill?兼容低版本瀏覽器方法,需要的朋友可以參考下

注意:本文主要介紹的 vue-cli 版本:3.x, 4.x;
最近在項目中使用 webpack 打包后升級,用戶反饋使用瀏覽器(chrome 45)訪問白屏。經(jīng)過排查發(fā)現(xiàn):由于 chrome 45 無法兼容 ES6 語法導(dǎo)致的,因此需要將項目中的 ES6 語法轉(zhuǎn) ES5 語法。

在這里插入圖片描述

1. 兼容低版本瀏覽器方法

1.1 安裝 babel-polyfill

babel-polyfill npm地址

npm i babel-polyfill

1.2 引入

方式一(推薦):main.js 頂部第一行

import 'babel-polyfill';

方式二:vue.config.js 中,在 chainWebpack 內(nèi)添加以下代碼

chainWebpack: config => {
  config.entry('main').add('babel-polyfill')
  config.entry.app = ['babel-polyfill', './src/main.js']
}

1.3(新增)在 babel.config.js 中配置

module.exports = {
  presets: [
    ['@vue/app', {
      polyfills: [
        'es6.promise',
        'es6.symbol',
        'es6.array.iterator',
        'es6.object.assign',
      ],
      useBuiltIns: 'entry',
    }],
  ],
}

1.4 在 vue.config.js (新增)配置 transpileDependencies

如果還引入了其他插件而該插件內(nèi)部也存在ES6寫法,則需要將這些插件的 ES6 轉(zhuǎn)換成 ES5,使用 transpileDependencies 直接將需要轉(zhuǎn)換的插件放入。

  transpileDependencies: [
    'element-ui', 'vant', 'js-cookie', 'vxe-table', 'xe-utils','vue-virtual-scroll-list','vue-socket.io'
  ],

vue-cli 官方文檔中 transpileDependencies 說明

在這里插入圖片描述

補充說明

  • 如安裝配置 babel-polyfill 后仍無法兼容低版本瀏覽器,可適當(dāng)降級 babel-polyfill 的版本;
  • 如使用 cnpm 安裝依賴,可能會導(dǎo)致 transpiledependencies 無效,具體原因還未深究。可直接將 node_modules 全部刪掉,重新使用 npm 安裝所有依賴后,再次重新打包,目前問題已解決;
  • vue-cli 使用 wokrer-loader 加載 web woker 時,使用 npm run build 有很大機率會打包失?。海▓箦e:Syntax Error: Thread Loader (Worker 4) The “from” argument must be of type string. Received undefined)。原因 :thread-loader 與 worker-loader 有沖突。解決: vue.config.js 中配置 parallel: false 。構(gòu)建正式環(huán)境關(guān)閉thread-loader。

2. vue-cli 2.x 中配置 babel 轉(zhuǎn)換

@babel/core:babel 的核心庫
必引,一切 babel 轉(zhuǎn)換操作都基于 @babel/core,因為它包含了編譯的 transform 方法

npm install --save-dev @babel/core

@babel/polyfill:用于模擬完整的 ES2015+ 環(huán)境
注意:–save 而非 --save-dev,因為這是需要在源碼之前運行的 polyfill;

npm install --save @babel/polyfill

安裝之后,在項目入口 main.js 引入 @babel/polyfill 即可;

babel-loader:webpack 配置 loader 轉(zhuǎn)換
babel-loader 允許使用 Babel 和 webpack 來轉(zhuǎn)譯 JavaScript 文件

npm install --save-dev babel-loader

webpack.base.config.js 文件中配置

module.exports = {
  module: {
    rules: [
      {
        test: /\.js$/,
        loader: 'babel-loader',
        include: [resolve('src')]
      }
    ]
  }
}

通過以上配置即可達到在 vue-cli 2.x 中進行 babel 轉(zhuǎn)換

拓展:關(guān)于 Babel 簡介

Babel 中文官方文檔

Babel 是一個工具鏈,主要用于將采用 ECMAScript 2015+ 語法編寫的代碼轉(zhuǎn)換為向后兼容的 JavaScript 語法,以便能夠運行在當(dāng)前和舊版本的瀏覽器或其他環(huán)境中。下面列出的是 Babel 能為你做的事情:1. 語法轉(zhuǎn)換;2. 通過 Polyfill 方式在目標(biāo)環(huán)境中添加缺失的特性 (通過引入第三方 polyfill 模塊,例如 core-js);3. 源碼轉(zhuǎn)換(codemods);

相關(guān)文章

  • Vue+ElementUI怎么處理超大表單實例講解

    Vue+ElementUI怎么處理超大表單實例講解

    在本篇文章里小編給大家整理的是一篇關(guān)于Vue+ElementUI怎么處理超大表單實例講解內(nèi)容,以后需要的朋友可以跟著學(xué)習(xí)參考下。
    2021-11-11
  • vue3如何自定義message彈窗

    vue3如何自定義message彈窗

    這篇文章主要介紹了vue3如何自定義message彈窗問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-04-04
  • vue項目部署自動清除緩存方式

    vue項目部署自動清除緩存方式

    這篇文章主要介紹了vue項目部署自動清除緩存方式,包括清除文件緩存,清除瀏覽器 localStorage 緩存方式,本文結(jié)合示例代碼給大家介紹的非常詳細(xì),需要的朋友可以參考下
    2023-07-07
  • vue傳值的編碼和解碼方式

    vue傳值的編碼和解碼方式

    這篇文章主要介紹了vue傳值的編碼和解碼方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-07-07
  • Vue自定義el-table表格表頭高度的多種實現(xiàn)方法

    Vue自定義el-table表格表頭高度的多種實現(xiàn)方法

    在Vue項目中,使用Element?UI的el-table組件可以輕松創(chuàng)建功能豐富的表格,然而,默認(rèn)情況下,el-table的表頭高度是固定的,本文將詳細(xì)介紹如何自定義el-table表頭的高度,提供多種實現(xiàn)方法,需要的朋友可以參考下
    2024-10-10
  • vue3 element-plus如何使用icon圖標(biāo)組件

    vue3 element-plus如何使用icon圖標(biāo)組件

    這篇文章主要介紹了vue3 element-plus如何使用icon圖標(biāo)組件問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-03-03
  • vue.js前后端數(shù)據(jù)交互之提交數(shù)據(jù)操作詳解

    vue.js前后端數(shù)據(jù)交互之提交數(shù)據(jù)操作詳解

    這篇文章主要介紹了vue.js前后端數(shù)據(jù)交互之提交數(shù)據(jù)操作,結(jié)合實例形式較為詳細(xì)的分析了vue.js前后端數(shù)據(jù)交互相關(guān)的表單結(jié)構(gòu)、約束規(guī)則、數(shù)據(jù)提交等相關(guān)操作技巧與注意事項,需要的朋友可以參考下
    2018-04-04
  • Vue3中Composition?API和Options?API的區(qū)別

    Vue3中Composition?API和Options?API的區(qū)別

    Vue3的Composition API和Options API是Vue.js框架中的兩種不同的API,本文主要介紹了Vue3中Composition?API和Options?API的區(qū)別,文中通過示例代碼介紹的非常詳細(xì),需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-06-06
  • vuex中mapState思想應(yīng)用

    vuex中mapState思想應(yīng)用

    這篇文章主要分享vuex中mapState思想及應(yīng)用,在需求開發(fā)過程中,有的接口返回的結(jié)果中有很多字段需要展示到頁面上。通??梢詫⑦@些字段在.vue文件中封裝為計算屬性,或者重新將對應(yīng)字段賦值到 data 中的字段來達到便于使用的目的,具體內(nèi)容,我們一起來看下面文章內(nèi)容吧
    2021-10-10
  • Vue3自動引入組件與組件庫的方法實例

    Vue3自動引入組件與組件庫的方法實例

    關(guān)于vue?組件還是非常好用的,真正掌握預(yù)計需要一段時間,下面這篇文章主要給大家介紹了關(guān)于Vue3自動引入組件與組件庫的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2022-10-10

最新評論