欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

在?Vite項目中使用插件?@rollup/plugin-inject?注入全局?jQuery的過程詳解

 更新時間:2022年12月01日 10:31:39   作者:Never?Yu  
在一次項目腳手架升級的過程中,將之前基于?webpack?搭建的項目移植到?Vite?構(gòu)建,這篇文章主要介紹了在?Vite項目中,使用插件?@rollup/plugin-inject?注入全局?jQuery,需要的朋友可以參考下

寫在前面

在一次項目腳手架升級的過程中,將之前基于 webpack 搭建的項目移植到 Vite 構(gòu)建。

一些組件庫是依賴 jQuery 的,如:Bootstrap;引入這些組件的時候,需要項目中已經(jīng)存在 jQuery 環(huán)境。

例如:當(dāng)我們在 main.js 中使用如下方式引入 Bootstrap 時:

// main.js
/* bootstarp */
import '@/assets/css/bootstrap.min.css'
import '@/assets/js/bootstrap.min.js'

我們必須保證擁有全局的 jQuery 環(huán)境。否則,在 Bootstrap 中會報缺少 jQuery 的錯誤。

在原項目中,在 webpack.base.conf.js 中,有一段關(guān)于 jQuery 的配置是這樣的:

module.exports = {
  ...
  plugins: [
    new webpack.ProvidePlugin({
      $: "jquery",
      jQuery: "jquery",
      "windows.jQuery": "jquery"
    })
  ],
  ...
}

使用 webpack.ProvidePlugin 插件全局注入 jQuery,這樣在項目構(gòu)建啟動運行后,項目中就有了全局的 jQuery 環(huán)境。

那么,在 Vite 的項目中,該如何來配置或者來實現(xiàn)這個功能呢?

方法一、全局靜態(tài)引入

全局靜態(tài)引入的意思,就是在項目的主頁面文件 index.html 中,使用原始引入 js 文件的方式來引入 jquery

<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <link rel="icon" type="image/svg+xml" href="/vite.svg" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <title>Vite-Vue3</title>
    <script src="/src/jquery.min.js"></script>
  </head>
  <body>
    <div id="app"></div>
    <script type="module" src="/src/main.js"></script>
  </body>
</html>

方法二、使用插件 @rollup/plugin-inject 注入 jquery

首先,安裝 jquery、@rollup/plugin-inject.

npm i jquery @rollup/plugin-inject -S

在項目的配置文件 vite.config.js 中:

import inject from '@rollup/plugin-inject'

// https://vitejs.dev/config/
export default defineConfig({
  plugins: [
    vue(),
    inject({
      $: "jquery",  // 這里會自動載入 node_modules 中的 jquery
      jQuery: "jquery",
      "windows.jQuery": "jquery"
    })
  ],
  resolve: {
    alias: {
      '@': resolve(__dirname, './src')
    }
  }
})

這樣,即可在 Vite 項目中實現(xiàn) webpack.ProvidePlugin 的功能。

課外知識:

一、關(guān)于 webpack.ProvidePlugin

了解 webpack 的插件使用方式:

// webpack.base.conf.js
const HtmlWebpackPlugin = require('html-webpack-plugin')

module.exports = {
  ...
  plugins: [
    new webpack.ProvidePlugin({}),
    new webpack.IgnorePlugin('/^\.\/locale$/, /moment$/'),
    // or(或者)
    new HtmlWebpackPlugin({
      template: './src/index.html'
    })
  ]
  ...
}

這里面有兩種 webpack 的插件使用方式:new webpack.ProvidePlugin()new HtmlWebpackPlugin();

前者是 webpack 內(nèi)置的模塊,后者不是 webpack 內(nèi)置的模塊,需要使用 npm 先進行安裝再使用。

  • ProvidePlugin,是 webpack 的內(nèi)置模塊。
  • 使用 ProvidePlugin 加載的模塊在使用時將不再需要 importrequire 進行引入。
  • jquery 為例,用 ProvidePlugin 進行實例初始化后,jquery 就會被自動加載并導(dǎo)入對應(yīng)的 node 模塊中。
new webpack.ProvidePlugin({
  $: 'jquery',
  jQuery: 'jquery'
})

// 然后我們可以在代碼中直接使用

$('#item'); // <= just works
jQuery('#item'); // <= just works
// $ is automatically set to the exports of module "jquery"

二、使用 @rollup/plugin-node-resolve 解決模塊之間引用問題

使用 @rollup/plugin-node-resolve 解決模塊之間引用問題。

到此這篇關(guān)于在 Vite項目中,使用插件 @rollup/plugin-inject 注入全局 jQuery的文章就介紹到這了,更多相關(guān)@rollup/plugin-inject 注入全局 jQuery內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Vue?transition組件簡單實現(xiàn)數(shù)字滾動

    Vue?transition組件簡單實現(xiàn)數(shù)字滾動

    這篇文章主要為大家介紹了Vue?transition組件簡單實現(xiàn)數(shù)字滾動示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-09-09
  • Vue2.0在IE11版本瀏覽器中的兼容性問題

    Vue2.0在IE11版本瀏覽器中的兼容性問題

    這篇文章主要介紹了Vue2.0在IE11版本瀏覽器中的兼容性問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-04-04
  • element上傳文件對格式限制的處理方案

    element上傳文件對格式限制的處理方案

    最近做項目遇到這樣的需求,需要上傳的文件格式必須是pdf格式,方便我們查看,本文給大家分享element上傳文件對格式限制的處理方案,感興趣的朋友一起看看吧
    2024-02-02
  • 前端H5微信支付寶支付實現(xiàn)方法(uniapp為例)

    前端H5微信支付寶支付實現(xiàn)方法(uniapp為例)

    最近上線一個項目,手機網(wǎng)站進行調(diào)起支付寶App支付,做起來還是滿順手的,在此做個記錄,這篇文章主要給大家介紹了關(guān)于前端H5微信支付寶支付實現(xiàn)方法的相關(guān)資料,需要的朋友可以參考下
    2024-04-04
  • Vue3?全局實例上掛載屬性方法案例講解

    Vue3?全局實例上掛載屬性方法案例講解

    這篇文章主要介紹了Vue3?全局實例上掛載屬性方法,本文通過示例代碼給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-05-05
  • vue項目下,如何用命令直接修復(fù)ESLint報錯

    vue項目下,如何用命令直接修復(fù)ESLint報錯

    這篇文章主要介紹了vue項目下,如何用命令直接修復(fù)ESLint報錯,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-04-04
  • vue中使用protobuf的過程記錄

    vue中使用protobuf的過程記錄

    由于目前公司采用了ProtoBuf做前后端數(shù)據(jù)交互,進公司以來一直用的是公司大神寫好的基礎(chǔ)庫,完全不了解底層是如何解析的。下面小編給大家分享vue中使用protobuf的過程記錄,需要的朋友參考下吧
    2018-10-10
  • 在vue3中安裝使用bootstrap過程

    在vue3中安裝使用bootstrap過程

    這篇文章主要介紹了在vue3中安裝使用bootstrap過程,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-10-10
  • vue?指令與過濾器案例代碼

    vue?指令與過濾器案例代碼

    這篇文章主要介紹了vue?指令與過濾器,本文通過案例代碼給大家詳細講解,給大家講解的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-11-11
  • vue3+axios封裝攔截器方式

    vue3+axios封裝攔截器方式

    介紹了如何在Vue項目中使用Axios封裝請求、配置攔截器,并在api.js中統(tǒng)一管理API接口,同時,也講解了如何在vite.config.js中配置解決跨域問題,這些操作可以優(yōu)化前端代碼結(jié)構(gòu),提高開發(fā)效率
    2024-09-09

最新評論