成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

教你搭建按需加載的Vue組件庫(kù)

宋華 / 3505人閱讀

摘要:先來(lái)看看是怎么做的,官方的的快速手上使用一個(gè)了插件,作用就是代碼轉(zhuǎn)換轉(zhuǎn)換為到這我們可以知道,要搭建一個(gè)按需加載的組件庫(kù)。

按需加載的原理

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

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

Vue.use(Button);

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

先來(lái)看看element是怎么做的,官方的的「快速手上」:

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

import { Button } from "components"

// 轉(zhuǎn)換為

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

到這我們可以知道,要搭建一個(gè)按需加載的組件庫(kù)。主要工作需要兩點(diǎn):

組件獨(dú)立打包,單個(gè)文件對(duì)應(yīng)單個(gè)組件

引入代碼轉(zhuǎn)換的插件

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

我們?cè)陧?xiàng)目的跟目錄建一個(gè)文件夾packages,下面放我們的組件:

packages下每一個(gè)文件夾對(duì)應(yīng)一個(gè)組件所需要的資源,在index.js定義組件的install方法。而packages/index.js存放了在全量加載時(shí)用的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:

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配置

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

多入口

每個(gè)組件獨(dú)立生成一個(gè)對(duì)應(yīng)的js和css,這就需要我們?cè)谌肟谔幘桶呀M件的引用定義好:

webpack.prod.conf.js:
const entrys = {
    Button: path.resolve(__dirname, "../packages/Button"),
    index: path.resolve(__dirname, "../packages")
};

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

上述配置每增加一個(gè)組件都需要修改entrys,我們可以優(yōu)化一下,使其動(dòng)態(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的輸出

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

output: {
    path: config.build.assetsRoot,
    filename: utils.assetsPath("[name].js"),
    library: "LoadOnDemand",
    libraryTarget: "umd"
},
配置 babel-plugin-component -D

上面的組件庫(kù)打包發(fā)布到npm上之后。我們?cè)谑褂玫臅r(shí)候npm install babel-plugin-component -D之后,修改一下.babelrc.js:

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

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

結(jié)語(yǔ)

上面demo的代碼放在了個(gè)人github
https://github.com/jmx164491960/load-on-demand
大家如果有更好的實(shí)現(xiàn)方法,或者我上面還有什么需要更正的錯(cuò)誤,歡迎交流。

文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/54269.html

相關(guān)文章

  • 教你搭建按需加載Vue組件庫(kù)

    摘要:先來(lái)看看是怎么做的,官方的的快速手上使用一個(gè)了插件,作用就是代碼轉(zhuǎn)換轉(zhuǎn)換為到這我們可以知道,要搭建一個(gè)按需加載的組件庫(kù)。 按需加載的原理 按需加載,本質(zhì)上是把一個(gè)組件庫(kù)的不同組件拆分成不同文件,按照需要引用對(duì)應(yīng)的文件,而該文件暴露一個(gè)install方法,供Vue.use使用。比如:我只想引用element庫(kù)里的一個(gè)Button組件 import Button from element-...

    callmewhy 評(píng)論0 收藏0
  • 個(gè)人分享--web前端學(xué)習(xí)資源分享

    摘要:前言月份開(kāi)始出沒(méi)社區(qū),現(xiàn)在差不多月了,按照工作的說(shuō)法,就是差不多過(guò)了三個(gè)月的試用期,準(zhǔn)備轉(zhuǎn)正了一般來(lái)說(shuō),差不多到了轉(zhuǎn)正的時(shí)候,會(huì)進(jìn)行總結(jié)或者分享會(huì)議那么今天我就把看過(guò)的一些學(xué)習(xí)資源主要是博客,博文推薦分享給大家。 1.前言 6月份開(kāi)始出沒(méi)社區(qū),現(xiàn)在差不多9月了,按照工作的說(shuō)法,就是差不多過(guò)了三個(gè)月的試用期,準(zhǔn)備轉(zhuǎn)正了!一般來(lái)說(shuō),差不多到了轉(zhuǎn)正的時(shí)候,會(huì)進(jìn)行總結(jié)或者分享會(huì)議!那么今天我就...

    sherlock221 評(píng)論0 收藏0
  • webpack 基礎(chǔ)與項(xiàng)目?jī)?yōu)化實(shí)踐總結(jié)

    摘要:前言本文基于,主要涉及基本概念基本配置和實(shí)際項(xiàng)目打包優(yōu)化。關(guān)于概念方面參考官網(wǎng),常用配置來(lái)自于網(wǎng)絡(luò)資源,在文末有相關(guān)參考鏈接,實(shí)踐部分基于自己的項(xiàng)目進(jìn)行優(yōu)化配置。同一文件中,修改某個(gè)影響其他。 前言:本文基于weboack4.x,主要涉及webpack4 基本概念、基本配置和實(shí)際項(xiàng)目打包優(yōu)化。關(guān)于概念方面參考官網(wǎng),常用配置來(lái)自于網(wǎng)絡(luò)資源,在文末有相關(guān)參考鏈接,實(shí)踐部分基于自己的項(xiàng)目進(jìn)行...

    Scorpion 評(píng)論0 收藏0
  • 一文教你構(gòu)建自己library、webpack優(yōu)化和npm版本控制

    摘要:地址點(diǎn)個(gè),給我們一點(diǎn)動(dòng)力中文文檔地址交流地址點(diǎn)個(gè),謝謝這套費(fèi)了幾個(gè)月時(shí)間和很多心血,現(xiàn)在已經(jīng)趨于完善,你完全可以在你的生產(chǎn)環(huán)境中試著使用。 介紹 構(gòu)建自己的UI庫(kù),你必須要對(duì)一款打包工具熟悉(webpack, gulp或者grunt), 本文以webpack為例。 github 地址: https://github.com/reming0227... (點(diǎn)個(gè) star,給我們一點(diǎn)動(dòng)力 ...

    劉玉平 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<