溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

webpack怎么打包一個按需引入的vue組件庫

發(fā)布時間:2022-02-14 09:54:32 來源:億速云 閱讀:252 作者:小新 欄目:開發(fā)技術

這篇文章給大家分享的是有關webpack怎么打包一個按需引入的vue組件庫的內容。小編覺得挺實用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。

    在項目中使用vue組件庫的一般姿勢

    • 1、通過import引入,并在入口文件main.js里使用Vue.use方法完成組件的全局注冊,便可在任何單文件組件中直接使用。如下

    import Vue from "vue"
    import App from "./App.vue"
    import mylib from "mylib"
    Vue.use(mylib)
    new Vue({
      render: h => h(App)
    }).$mount("#app");
    • 2、上面的方式看似是一勞永逸,可隨著組件庫越發(fā)的壯大,會出現(xiàn)我引入了整個組件庫代碼,但我在目前的項目里只使用了其中一小部分組件,但在項目最終打包的時候卻把組件庫里所有的組件代碼都打包進了bundle文件里,影響了最終代碼體積,這明顯是不合理的。所以便有了按需引入組件庫的方式,這里我們參考element-ui的按需引入方式,如下。

    webpack怎么打包一個按需引入的vue組件庫

    接下來,如果你只希望引入部分組件,比如 Button 和 Select,那么需要在 main.js 中寫入以下內容:

    import Vue from 'vue'; 
    import { Button, Select } from 'element-ui'; 
    import App from './App.vue'; 
    Vue.component(Button.name, Button); 
    Vue.component(Select.name, Select);  
    new Vue({
        el: '#app', 
        render: h => h(App) 
    });

    為什么這樣具名導入組件就可以做到按需引入呢?其實是babel-plugin-component插件幫我們完成了轉換的工作。在babel-plugin-component內部會把

    import { Button, Select } from 'element-ui';

    轉換成

    var button = require('element-ui/lib/button')
    var select = require('element-ui/lib/select')
    require('element-ui/lib/theme-chalk/button/style.css')
    require('element-ui/lib/theme-chalk/select/style.css')

    上面的element-ui是組件庫名,theme-chalk是組件庫樣式所在的文件夾名,都是可以配置的。buttonselect是組件名,lib是babel-plugin-component插件默認尋找組件的文件夾。

    webpack實現(xiàn)可按需引入的組件庫

    npm init創(chuàng)建項目,因為是每個組件單獨打包,所以每個組件都導出一個函數(shù),再Vue.use()的時候執(zhí)行這個函數(shù),完成組件的全局注冊。項目目錄結構如下

    webpack怎么打包一個按需引入的vue組件庫

    components/navbar/navbar.vue
    <template>
      <div class="header__all">{{text}}</div>
    </template>
    <script>
    export default {
      name: "navbar",
      props: {
        text: String
      }
    };
    </script>
    <style rel="stylesheet/scss" lang="scss" scoped>
    .header__all{
        background-color: #000000;
        color: #FFFFFF;
        display: flex;
        justify-content: center;
        align-items: center;
        height: 50px;
        width: 100%;
    }
    </style>
    components/navbar/index.js
    import navbar from "./navbar.vue";
    export default function(Vue) {
        Vue.component(navbar.name,navbar);
    }
    src/index.js
    import navbar from "./components/navbar"
    function install(Vue){
      Vue.use(navbar)
    }
    if(window && window.Vue) {
      Vue.use(install)
    }
    export default install

    接下來就是使用webpack打包

    • 第一步:先安裝所有需要用到的依賴

    npm i -D webpack webpack-cli babel-loader @babel/core @babel/preset-env babel-plugin-component clean-webpack-plugin css-loader mini-css-extract-plugin node-sass postcss postcss-loader autoprefixer cssnano sass-loader terser-webpack-plugin vue-loader vue-template-compiler
    • 第二步:配置webpack.config.js

    const path = require('path')
    const TerserPlugin = require("terser-webpack-plugin");
    const { CleanWebpackPlugin } = require("clean-webpack-plugin")
    const { VueLoaderPlugin } = require('vue-loader')
    const MiniCssExtractPlugin = require('mini-css-extract-plugin')
    module.exports = {
      mode: 'none',
      entry: {
        'navbar': './src/components/navbar/index.js',
        'navbar.min': './src/components/navbar/index.js',
        'test-lib': './src/index.js',
        'test-lib.min': './src/index.js'
        
      },
      output: {
        path: path.join(__dirname,"/lib"),
        filename: '[name].js',
        libraryTarget: 'umd',
        library: '[name]',
        libraryExport: 'default'
      },
    //   externals:[],
      optimization: {
        minimize: true,
        minimizer: [
            new TerserPlugin({
                test: /\.min\.js$/,
            }),
        ],
      },
      module: {
        rules: [
          {
            test: /\.vue$/,
            use:  ['vue-loader']
          },
          {
            test: /\.css$/,
            use:  [MiniCssExtractPlugin.loader,'css-loader','postcss-loader']
          },
          {
              test: /\.s[ac]ss$/i,
              use:  [MiniCssExtractPlugin.loader,'css-loader','postcss-loader','sass-loader']
          },
          {
            test: /\.js$/,
            exclude: /node_modules/,
            use:{
                loader: 'babel-loader',
                options: {
                    cacheDirectory: true
                }
            }
            
          }
        ]
      },
      plugins: [
        new VueLoaderPlugin(),
        new CleanWebpackPlugin(),
        new MiniCssExtractPlugin({
            filename: 'lib-style/[name].css'
        })
      ]
    }
    • 第三步:更改package.json的main字段,并往scripts里添加打包命令

    "main": "./lib/test-lib.min.js",
    "scripts": {
        "build": "webpack --config webpack.config.js"
    }
    • 第四步:執(zhí)行 npm run build 打包組件庫,成功后項目多了個lib文件夾,存放打包后組件庫的代碼。lib文件夾里每個文件都有一個對應的.min文件,.min文件分別用terser-webpack-plugin插件和cssnano壓縮。

    webpack怎么打包一個按需引入的vue組件庫

    調試組件庫

    有兩種方式可調試本地的組件庫

    • 新建test.html,然后以

    • vuecli新建個測試項目,然后通過npm link的方式鏈接到測試項目中去使用

    這里展示就使用最粗暴的方式一,新建test.html,npm link各位看官老爺可以自己去嘗試下。

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <meta name="viewport" content="width=device-width, initial-scale=1.0">
        <title>Document</title>
        <link rel="stylesheet" href="./lib/lib-style/test-lib.min.css" rel="external nofollow" >
    </head>
    <body>
        <div id="app">
            <navbar text="header"></navbar>
        </div>
    </body>
    <script src="https://cdn.jsdelivr.net/npm/vue/dist/vue.js"></script>
    <script src="./lib/test-lib.min.js"></script>
    <script>
        new Vue({
            el: '#app'
        })
    </script>
    </html>

    測試結果:

    webpack怎么打包一個按需引入的vue組件庫

    到這一步,至少說明代碼構建沒什么大問題,但按需引入功能還沒驗收,接下來我們就繼續(xù)把組件庫發(fā)布到npm上,完全效仿element-ui的使用方式在vuecli項目中使用,看看實現(xiàn)的效果如何。

    npm 發(fā)布

    步驟非常簡單,只需4步

    • 在npm官網(wǎng)注冊賬號并驗證郵箱。

    • 在命令行中輸入 npm login 完成登錄。

    • 如果npm使用的是淘寶鏡像源,需要切回npm源。

    • 進入需要發(fā)布的項目目錄執(zhí)行npm publish 發(fā)布。

    完成后,接著就在測試項目里 npm install 安裝我們自己的組件庫。

    調試組件庫按需引入

    在測試項目里的babel.config.js,添加babel-plugin-component配置,并重啟項目。
    babel-plugin-component基本配置參考

    // babel.config.js
    module.exports = {
      presets: ["@vue/cli-plugin-babel/preset"],
      plugins: [
        [
          'component',
          {
            libraryName: 'element-ui',
            styleLibraryName: 'theme-chalk'
          },
          'element-ui'
        ],
        [
          'component',
          {
            libraryName: 'test-lib',
            styleLibrary: {
              "name": "lib-style", // same with styleLibraryName
              "base": false  // if theme package has a base.css
            }
          },
          'test-lib'
        ],
      ]
    };

    在test.vue中使用組件庫

    <template>
    <div>
      <navbar :text="msg"></navbar>
      <el-button type="primary" class="dg-margin-t-20">element-button</el-button>
    </div>
    </template>
    <script>
    import Vue from "vue";
    import { navbar } from "juejintest-lib";
    import { button } from "element-ui";
    Vue.use(navbar)
    Vue.use(button)
    export default {
      data:function() {
          return {
              msg: 'text'
          }
      }
    };
    </script>
    <style lang="scss">
    .dg-margin-t-20{
        margin-top:20px;
    }
    </style>

    webpack怎么打包一個按需引入的vue組件庫

    感謝各位的閱讀!關于“webpack怎么打包一個按需引入的vue組件庫”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,讓大家可以學到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!

    向AI問一下細節(jié)

    免責聲明:本站發(fā)布的內容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權內容。

    AI