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

教你搭建按需加載的Vue組件庫(小結(jié))

 更新時間:2019年07月29日 10:25:33   作者:墨工  
這篇文章主要介紹了教你搭建按需加載的Vue組件庫(小結(jié)),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧

按需加載的原理

按需加載,本質(zhì)上是把一個組件庫的不同組件 拆分成不同文件 ,按照需要引用對應(yīng)的文件,而該文件暴露一個 install方法 ,供Vue.use使用。 比如:我只想引用element庫里的一個Button組件

import Button from 'element-ui/lib/Button.js'
import Button from 'element-ui/lib/theme-chalk/Button.css'

Vue.use(Button);

上面的寫法比較繁瑣,而且需要知道每個組件的實際路徑,使用起來并不方便,所以我們還需要借助一個轉(zhuǎn)換插件。

先來看看 element 是怎么做的,官方的的「快速手上」:

element使用一個了babel插件,作用就是代碼轉(zhuǎn)換:

import { Button } from 'components'

// 轉(zhuǎn)換為

var button = require('components/lib/button')
require('components/lib/button/style.css')

到這我們可以知道,要搭建一個按需加載的組件庫。 主要工作 需要兩點:

  1. 組件獨立打包 ,單個文件對應(yīng)單個組件
  2. 引入 代碼轉(zhuǎn)換 的插件

組件代碼的編寫規(guī)范

我們在項目的跟目錄建一個文件夾packages,下面放我們的組件:

packages下每一個文件夾對應(yīng)一個組件所需要的資源,在index.js定義組件的install方法。而packages/index.js存放了在全量加載時用的install方法

packages/Button/index.js:

import Button from './src/main';

Button.install = function(Vue) {
 Vue.component(Button.name, Button);
};

export default Button;

packages/Button/src/main.vue:

<template>
 <div>
 我是一個Button組件
 </div>
</template>

packages/index.js:

import Button from './Button';
import Loading from './Loading';
import LoadMore from './LoadMore';

const components = [
 Button,
 LoadMore,
 Loading
];

const install = function(Vue) {
 components.forEach(component => {
 Vue.component(component.name, component);
 });
}

if (typeof window !== 'undefined' && window.Vue) {
 install(window.Vue)
}

export default {
 install, // 全量引入
 Button,
 LoadMore,
 Loading
};

webpack配置

組件代碼寫好了,接下來需要配置一下webpack的打包邏輯。我們復(fù)用vue-cli生成的模板,在上面做一些必要更改:

多入口

每個組件獨立生成一個對應(yīng)的js和css,這就需要我們在入口處就把組件的引用定義好:

webpack.prod.conf.js:

const entrys = {
 Button: path.resolve(__dirname, '../packages/Button'),
 index: path.resolve(__dirname, '../packages')
};

const webpackConfig = merge(baseWebpackConfig, {
 entry: entrys,
 // ......
});

上述配置每增加一個組件都需要修改entrys,我們可以優(yōu)化一下,使其 動態(tài)生成

webpack.prod.conf.js:

const entrys = require(./getComponents.js)([組件目錄入口]);
const webpackConfig = merge(baseWebpackConfig, {
 entry: entrys,
 ......
});

getComponents.js:

const fs = require('fs');
const path = require('path');

/**
 * 判斷剛路徑是否含有index.js
 * @param {String} dir 
 */
function hasIndexJs(dir) {
 let dirs = [];
 try {
  dirs = fs.readdirSync(dir);
 } catch(e) {
  dirs = null;
 }
 return dirs && dirs.includes('index.js');
}

/**
 * 獲取指定入口和入口下包含index.js的文件夾的路徑
 * @param {String} entryDir 
 */
const getPath = function(entryDir) {
 let dirs = fs.readdirSync(entryDir);
 
 const result = {
  index: entryDir
 };
 dirs = dirs.filter(dir => {
  return hasIndexJs(path.resolve(entryDir, dir));
 }).forEach(dir => {
  result[dir] = path.resolve(entryDir, dir); 
 });
 return result;
}

module.exports = getPath;

修改webpack的輸出

默認生成的js文件并不支持ES6引入,在這里我們設(shè)置成 umd

output: {
 path: config.build.assetsRoot,
 filename: utils.assetsPath('[name].js'),
 library: 'LoadOnDemand',
 libraryTarget: 'umd'
},

配置 babel-plugin-component -D

上面的組件庫打包發(fā)布到npm上之后。我們在使用的時候npm install babel-plugin-component -D之后,修改一下.babelrc.js:

"plugins": [
 [
  "component",
  {
  "libraryName": "load-on-demand", // 組件庫的名字
  "camel2Dash": false, // 是否把駝峰轉(zhuǎn)換成xx-xx的寫法
  "styleLibrary": {
   "base": false, // 是否每個組件都默認引用base.css
   "name": "theme" // css目錄的名字
  }
  }
 ]
 ],

這里提一下屬性 camel2Dash ,默認是開啟的,開啟狀態(tài)下假如你的組件名是vueCompoent,引用的css文件會變成vue-component.css。

結(jié)語

上面demo的代碼放在了個人github github.com/jmx16449196… 大家如果有更好的實現(xiàn)方法,或者我上面還有什么需要更正的錯誤,歡迎交流。

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • Vue3 diff算法之雙端diff算法詳解

    Vue3 diff算法之雙端diff算法詳解

    雙端Diff在可以解決更多簡單Diff算法處理不了的場景,且比簡單Diff算法性能更好。本文將通過示例為大家詳細講講雙端diff算法的實現(xiàn)與使用,需要的可以參考一下
    2022-09-09
  • vue3父子組件通信、兄弟組件實時通信方式

    vue3父子組件通信、兄弟組件實時通信方式

    這篇文章主要介紹了vue3父子組件通信、兄弟組件實時通信方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-06-06
  • 手寫vue無限滾動指令的詳細過程

    手寫vue無限滾動指令的詳細過程

    今天在移動端項目中遇見一個需求,需要數(shù)據(jù)無限滾動,所以下面這篇文章主要給大家介紹了關(guān)于手寫vue無限滾動指令的詳細過程,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下
    2022-09-09
  • three.js實現(xiàn)vr全景圖功能實例(vue)

    three.js實現(xiàn)vr全景圖功能實例(vue)

    去年全景圖在微博上很是火爆了一陣,正好我也做過一點全景相關(guān)的項目,下面這篇文章主要給大家介紹了關(guān)于three.js實現(xiàn)vr全景圖功能的相關(guān)資料,文中通過代碼介紹的非常詳細,需要的朋友可以參考下
    2024-05-05
  • Vue中構(gòu)造數(shù)組數(shù)據(jù)之map和forEach方法實現(xiàn)

    Vue中構(gòu)造數(shù)組數(shù)據(jù)之map和forEach方法實現(xiàn)

    數(shù)組操作是前端最重要的數(shù)據(jù)操作,構(gòu)造數(shù)組數(shù)據(jù),又是數(shù)組操作中很常見的,本文將梳理下map和forEach方法在Vue項目中的使用,感興趣的朋友跟隨小編一起看看吧
    2022-09-09
  • vue封裝jquery修改自身及兄弟元素的方法

    vue封裝jquery修改自身及兄弟元素的方法

    本文主要介紹了vue封裝jquery修改自身及兄弟元素的方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2022-07-07
  • vue中動態(tài)渲染數(shù)據(jù)時使用$refs無效的解決

    vue中動態(tài)渲染數(shù)據(jù)時使用$refs無效的解決

    這篇文章主要介紹了vue中動態(tài)渲染數(shù)據(jù)時使用$refs無效的解決方案,具有很好的參考價值。希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-01-01
  • Vue + Webpack + Vue-loader學習教程之相關(guān)配置篇

    Vue + Webpack + Vue-loader學習教程之相關(guān)配置篇

    這篇文章主要介紹了關(guān)于Vue + Webpack + Vue-loader的相關(guān)配置篇,文中通過示例代碼介紹的非常詳細,相信對大家具有一定的參考價值,需要的朋友們下面來一起看看吧。
    2017-03-03
  • 總結(jié)Vue Element UI使用中遇到的問題

    總結(jié)Vue Element UI使用中遇到的問題

    這篇文章主要介紹了Vue Element UI使用中遇到的問題,對ElementUI感興趣的同學,可以參考下
    2021-05-05
  • vue.js提交按鈕時進行簡單的if判斷表達式詳解

    vue.js提交按鈕時進行簡單的if判斷表達式詳解

    這篇文章主要給大家介紹了關(guān)于vue.js提交按鈕時如何進行簡單的if判斷表達式的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2018-08-08

最新評論