element-ui 打包流程源码解析(上)

这篇具有很好参考价值的文章主要介绍了element-ui 打包流程源码解析(上)。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

分析版本为 element-ui,v2.15.9。

1,源码整体结构

1.1,build 目录

打包目录,包括所有的打包配置 webpack 等 js 文件。

1.2,examples 目录

element-ui 官网的源代码,是一个独立的 vue2 项目。通过脚本 build/webpack.demo.js 打包。

1.3,packages 目录

  1. 每个组件都是一个单独的文件夹。
  2. 组件对应的样式没有写在 .vue 文件中,而是统一在 packages/theme-chalk 目录,该目录是单独打包的,也可单独发版。

1.4,src 目录

  1. 基于模块化开发的思想,把组件使用到了依赖,和一些公共模块放在该目录下,并依据功能拆分出以下模块:
    1. utils,定义一些工具方法。
    2. transition,动画。
    3. mixins,全局混入的一些方法。
    4. local,国际化功能以及各种语言的部分组件的翻译文件。
    5. directives,指令。
  2. /src/index.js 是组件库入口文件,是通过脚本 /build/bin/build-entry.js 自动生成。
    • 负责自动导入组件库的所有组件。
    • 定义全量注册组件库组件的 install 方法。
    • 导出版本信息、install 和 各个组件。

2,打包整体流程

package.json 中的命令进行分析:

{
  "scripts": {
    "dist": "npm run clean && npm run build:file && npm run lint && webpack --config build/webpack.conf.js && webpack --config build/webpack.common.js && webpack --config build/webpack.component.js && npm run build:utils && npm run build:umd && npm run build:theme",
    "build:file": "node build/bin/iconInit.js & node build/bin/build-entry.js & node build/bin/i18n.js & node build/bin/version.js",
    "build:utils": "cross-env BABEL_ENV=utils babel src --out-dir lib --ignore src/index.js",
    "build:umd": "node build/bin/build-locale.js",
    "build:theme": "node build/bin/gen-cssfile && gulp build --gulpfile packages/theme-chalk/gulpfile.js && cp-cli packages/theme-chalk/lib lib/theme-chalk",
  }  
}

npm run dist 就是打包命令,配置的其他命令为它服务。

2.1,npm run build:file

2.1.1,build/bin/iconInit.js

目标文件:packages/theme-chalk/src/icon.scss

生成目录:examples/icon.json

生成内容:提取了所有的 icon 图标对应的类名。

["platform-eleme","eleme","delete-solid","delete","s-tools","setting"]

2.1.2,build/bin/build-entry.js

目标文件:components.json

生成目录:src/index.js

生成内容:组件库的入口文件。

2.1.3,build/bin/i18n.js

目标文件:examples/i18n/page.json+examples/pages/template

生成目录:examples/pages下,每种语言对应一个文件夹。

生成内容:官网项目页面的vue文件。

2.1.4,build/bin/version.js

package.json 中的当前版本信息,添加到已有 version 集合中。

生成目录:examples/versions.json

生成内容:版本号集合。

{"1.4.13":"1.4","2.0.11":"2.0","2.1.0":"2.1"}

2.2,build/webpack.conf.js

作用:全量打包组件库为 umd 模块。可通过 script 标签引入组件库来使用。

入口文件:src/index.js

生成目录:lib/index.js

2.3,build/webpack.common.js

作用:全量打包为 commonjs2 模块。可通过 npm 下载组件库来使用。

入口文件:src/index.js

生成目录:lib/element-ui.common.js。也就是 package.jsonmain,入口文件。

2.4,build/webpack.component.js

作用:为实现组件库的按需加载,将每个组件模块单独打包。

入口文件:components.json,组件库路径集合。

{
  "pagination": "./packages/pagination/index.js",
  "dialog": "./packages/dialog/index.js",
  // ...
}

输出目录:

-- lib
  -- pagination.js
  -- dialog.js
  -- ...

2.5,npm run build:utils

具体的命令解析,看这篇文章 babel相关

目标文件:src目录下除 index.js

-- src
  -- directives
  -- locale
  -- mixins
  -- transitions
  -- utils
  -- index.js // 不包括这个。

生成目录:都打包到 lib 目录下,打包为 commonjs 模块。

-- lib
  -- directives
  -- locale
  -- mixins
  -- transitions
  -- utils

需要的注意的是:babel 打包时指定了别名。

在源文件中,引用的路径:

import { once, on } from 'element-ui/src/utils/dom';

打包后,为了在 lib 目录中得到正确的引用路径。

exports.__esModule = true;

var _dom = require('element-ui/lib/utils/dom');

2.6,npm run build:umd

node build/bin/build-locale.js

目标文件:src/locale/lang,目录下是多语言的翻译文件——组件需要使用的翻译。

-- src
  -- es.js
  -- zh-CN.js
  // ...

生成目录

-- lib
  -- umd
    -- locale
      -- es.js
      -- zh-CN.js
      // ...

并且替换了部分内容

(function (global, factory) {
  if (typeof define === "function" && define.amd) {
    // 原:define('zh-CN', ['module', 'exports'], factory);
    define('element/locale/zh-CN', ['module', 'exports'], factory);
  } else if (typeof exports !== "undefined") {
    factory(module, exports);
  } else {
    var mod = {
      exports: {}
    };
    factory(mod, mod.exports);
    // 原:global.zhCN = mod.exports;
    global.ELEMENT.lang = global.ELEMENT.lang || {}; 
    global.ELEMENT.lang.zhCN = mod.exports;
  }
})(this, function (module, exports) {
  // 被打包文件的内容
}

作用:使用 babel 将目标文件打包为 umd 模块。可以看到替换了 root 环境下的内容。

2.7,npm run build:theme

作用:打包 scss 和 字体文件。

2.7.1,build/bin/gen-cssfile

作用:创建 packages/theme-chalk/src/index.scss,并引入 packages/theme-chalk 目录下所有组件的 scss 文件。

// index.scss
@import "./base.scss";
@import "./pagination.scss";
@import "./dialog.scss";
@import "./autocomplete.scss";
// ...

2.7.2,gulp build --gulpfile packages/theme-chalk/gulpfile.js

目标文件:packages/theme-chalk/src 目录下所有 scss 文件和 fonts 目录下的字体文件

生成目录:packages/theme-chalk/lib

-- packages/theme-chalk/lib
  -- fonts
    // 2个字体.tff
  -- alert.css
  -- aside.css
  // ...其他组件 css 文件

2.7.3,cp-cli packages/theme-chalk/lib lib/theme-chalk

将上面生成的 css 和字体文件复制到 lib/theme-chalk 目录下。


至此,npm run dist 命令执行完毕,输出都在 lib 目录下。

-- lib
  -- directives
  -- locale
  -- mixins
  -- transitions
  -- utils
  -- theme-chalk
    -- fonts
    -- alert.css
    // ...
  -- umd
    -- locale
      -- es.js
      -- zh-CN.js
      // ...  
  -- pagination.js
  -- dialog.js
  -- ...
  -- element-ui.common.js
  -- index.js

和 element 官网 介绍使用的 CDN 下的 lib 目录一致。

和我们通过 npm 下载的 element-ui 的 node_modules/element-ui/lib 一致。


为什么要这样打包,参考 element-ui 打包流程解析(下)- 目录结构和使用。

以上。文章来源地址https://www.toymoban.com/news/detail-804646.html

到了这里,关于element-ui 打包流程源码解析(上)的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • vue项目打包上线element-ui的icon偶尔乱码问题

    线上环境偶尔会复现, 具体: 一般使用不会出现这个问题,因为一般引入的是element-ui的css文件,问题出在于为了主题色变化啊,需要用到scss变量引入了scss文件。 @import “~element-ui/packages/theme-chalk/src/index”; 而dart-sass在编译element-ui里icon伪元素的content unicode编码时会转换成对

    2023年04月17日
    浏览(32)
  • vue打包后与本地测试样式不同问题,element-ui样式打包部署前后样式不同。

    个别文件的样式中style未加scope 。 查找到一些文件中修改了对应页面的elementUI的样式,但未加scope 给style加上scope,就好了。

    2024年01月25日
    浏览(37)
  • 修改element-ui源码

    element-ui修改源码 1.首先,从git上拉取element的源码 2.安装依赖 npm install 3.修改 packages 中的源码,然后进行打包 npm run dist 4.找到你的项目中的 node_modules 包下的 element-ui 文件夹下的 lib 包,用你修改好后打包生成的 lib 包进行替换即可生效 下载链接在官网底部

    2024年02月11日
    浏览(30)
  • vue element-ui blur触发事件 vue中使用@blur获取input val值 elementui+vue

    vue中使用@blur获取input val值

    2024年02月11日
    浏览(37)
  • 解决 elementUI 的 table 表格改变数据不更新问题 解决 vue数据不更新问题 element-ui 表格数据不更新

    利用 v-if这些都是一个逻辑,都是改变事件,达到数据刷新,没必要用 v-if 消耗性能 比较耗性能

    2023年04月08日
    浏览(40)
  • 【前端】Element-UI和Element-Plus的区别

    Element-UI对应Element2:基本不支持手机版 Element-Plus对应Element3:组件布局考虑了手机版展示 Element-ui适用于Vue2框架 Element-plus适用于Vue3框架 在element-ui中的dialog有 :visible.sync属性 可进行父子组件之间的双向绑定(vue2写法) 具体的写法为: 需要在computed中进行告知操作 在props传值

    2024年02月11日
    浏览(48)
  • Vue2 +Element-ui实现前端页面

    以一个简单的前端页面为例。主要是利用vue和element-ui实现。 里面涉及的主要包括:新建vue项目、一行多个输入框、页面实现等。   ①首先安装nodejs,这部分在此就不讲啦。 ②然后安装vue-cli: 查看是否安装成功: 安装成功之后就输出vue的版本 ③在cmd窗口新建一个vue2脚手架

    2024年02月16日
    浏览(35)
  • Springboot04--vue前端部分+element-ui

    注意点:  这边v-model和value的区别:v-model是双向绑定的,value是单向绑定 li的key的问题  vue的组件化开发:  安装完之后可以在cmd里面使用以下指令  安装好之后,找到你放代码的目录,cmd,然后npm install -g @vue/cli  新手选第三个,然后取消掉下面这个  运行项目的代码:  

    2024年02月13日
    浏览(30)
  • element-ui checkbox 组件源码分享

    简单分享 checkbox 组件,主要从以下三个方面来分享: 1、组件的页面结构 2、组件的属性 3、组件的方法 一、组件的页面结构 二、组件的属性 2.1 value / v-model 属性,绑定的值,类型 string / number / boolean,无默认值。 首先讨论单个 checkbox,通过 props 接收 父组件传递过来的 va

    2024年03月24日
    浏览(78)
  • Element-UI源码学习——弹框组件

    首先,分析一下Element-UI的对话框,点击,会弹出一个对话框。对话框由具体的弹框内容、关闭或确认按钮、外围的遮罩层组成。首先,先看下elmentui的用法: el-dialog组件里面可进行配置 效果: 1、dom实现: 外面的div实现遮罩层,里面的div是具体的内容 css: 2、弹框类的组件

    2024年02月12日
    浏览(33)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包