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

在?Vite項(xiàng)目中使用插件?@rollup/plugin-inject?注入全局?jQuery的過(guò)程詳解

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

寫在前面

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

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

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

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

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

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

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

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

那么,在 Vite 的項(xiàng)目中,該如何來(lái)配置或者來(lái)實(shí)現(xiàn)這個(gè)功能呢?

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

全局靜態(tài)引入的意思,就是在項(xiàng)目的主頁(yè)面文件 index.html 中,使用原始引入 js 文件的方式來(lái)引入 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

在項(xiàng)目的配置文件 vite.config.js 中:

import inject from '@rollup/plugin-inject'

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

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

課外知識(shí):

一、關(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 先進(jìn)行安裝再使用。

  • ProvidePlugin,是 webpack 的內(nèi)置模塊。
  • 使用 ProvidePlugin 加載的模塊在使用時(shí)將不再需要 importrequire 進(jìn)行引入。
  • jquery 為例,用 ProvidePlugin 進(jìn)行實(shí)例初始化后,jquery 就會(huì)被自動(dòng)加載并導(dǎo)入對(duì)應(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 解決模塊之間引用問(wèn)題

使用 @rollup/plugin-node-resolve 解決模塊之間引用問(wèn)題。

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

相關(guān)文章

  • Vue?transition組件簡(jiǎn)單實(shí)現(xiàn)數(shù)字滾動(dòng)

    Vue?transition組件簡(jiǎn)單實(shí)現(xiàn)數(shù)字滾動(dòng)

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

    Vue2.0在IE11版本瀏覽器中的兼容性問(wèn)題

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

    element上傳文件對(duì)格式限制的處理方案

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

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

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

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

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

    vue項(xiàng)目下,如何用命令直接修復(fù)ESLint報(bào)錯(cuò)

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

    vue中使用protobuf的過(guò)程記錄

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

    在vue3中安裝使用bootstrap過(guò)程

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

    vue?指令與過(guò)濾器案例代碼

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

    vue3+axios封裝攔截器方式

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

最新評(píng)論