0x00.前言 书接上文.项目经过一系列的配置,开发脚手架已经搭建完毕.接下来开始封装自定义组件.并基于 markdown 文件生成文档和演示案例. 后续文章代码会根据篇幅,不影响理解的情况下进行部分删减,详细代码可在 Github Repo 查看. 0x01.封装第一个组件 封装组件 接下来封装一个loading组件. 创建 packages/loading/src/main.vue 文件(篇幅问题,样式代码详见Github). 创建 packages/loading/index.js 文件.…
0x00.前言 书接上文.项目第一个组件已经封装好,说明文档也已编写好.下面需要将说明文档发布到外网上,以此来展示和推广项目,使用 Github Pages功能实现.同时将组件发布之 npm 上,方便直接在项目中安装使用. 0x01.Github Pages发布 进入项目的 Github repo,点击右上角的 Settings 选项. 点击左侧菜单的 Pages 选项,右侧显示项目 Github Pages 初始配置.source 配置项值为 None 说明此功能尚未开启. 点击 source…
前言 经常我们会遇到elementUI组件库期间有5%达不到我们想要的需求,第一我们重新写组件,第二我们改源码 安装element https://github.com/ElemeFE/element.git 新建组件 1.packages文件夹中新建alertText/src/main.vue <template> <div> <div>新增alertText组件测试</div> <input :type="typeInput"…
最近在用element-ui重构前端项目,无意之中翻阅到一个比较好用的组件间通信方式,借助于vue的封装的发布-订阅消息模式与mixin语法.在开始之前先总结下vue常用的组件间通信方式,具体如下: 1.props与自定义事件 优点:常用的父子.子父组件传递方式,简单易懂 缺点:子父.父子之间传参比较高效,但是爷孙,兄弟组件之间存在通信短板,只能一级级传递 2.vue 2.4中新增的$attrs与$listeners 优点:解决了组件嵌套层次较深问题,通过在组件中绑定组件的属性值与监听组件的事件…
书接上文,接下来项目将引入babel支持ES6+语法兼容. Babel 是一个工具链,主要用于将 ECMAScript 2015+ 版本的代码转换为向后兼容的 JavaScript 语法,以便能够运行在当前和旧版本的浏览器或其他环境中.中文官网 0x00.babel概念 Babel 是一个编译器(输入源码 => 输出编译后的代码).编译过程分为三个阶段:解析.转换和打印输出. Babel 本身不具有任何转化功能,它把转化的功能都分解到一个个plugin 里面.因此当我们不配置任何插件时,经过 b…
https://athena0304.github.io/element-analysis/ 1.模板字符串实现字符串拼接 typeClass() { return `el-alert--${ this.type }`; }, 2.inject inject,与父组件中的provide相对应,provide 选项允许我们指定我们想要提供给后代组件的数据/方法.相比 $parent 来说,这个用法可以让我们在任意后代组件中访问provide里的内容. // dropown.vue provide(…
书接上文.在团队协作中,为避免低级Bug.以及团队协作时不同代码风格对彼此造成的困扰与影响,会预先制定编码规范.使用 Lint工具和代码风格检测工具,则可以辅助编码规范执行,格式化代码,使样式与规则保持一致,有效控制代码质量,实现项目代码风格统一. 在代码格式化方面, Prettier 和 ESLint 有重叠,但两者侧重点不同:ESLint 所能提供的格式化功能很有限:而 Prettier 在格式化代码方面具有更大优势.而 Prettier 被设计为易于与 ESLint 集成,所以在项目中使用…
0x.00 前言 项目工程化系列文章链接如下,推荐按照顺序阅读文章 . 1️⃣ 源码剖析之工程化(一):项目概览.package.json.npm script 2️⃣ 源码剖析之工程化(二):项目构建.MD解析 3️⃣ 源码剖析之工程化(三):打包配置 前文对项目目录结构.package.json.npm script各命令任务内容和执行过程进行了概述.书接上文,build 目录下定义了许多项目构建脚本和配置(开发,打包,部署,持续集成). npm script各命令作为入口,会调用 buil…
0x.00 前言 在用了5章篇幅 ElementUI源码学习:从零开始搭建Vue组件库汇总 讲解了如何编写一个组件.发布npm以及生成展示文档之后.接下来将分析Element项目的代码结构,学习其工程化思想. 前端开发早已从瘦客户端(thin client)架构/中心服务器(server-centric)架构进入到胖客户端(fat client)架构,各家技术百花齐放,让人目不暇接,直呼学不动了!伴随项目开发的复杂度日益增高,开发中需要直面各种问题: 开发效率.产品质量.多人协作等. 前端工程化…
0x.00 前言 项目工程化系列文章链接如下,推荐按照顺序阅读文章 . 1️⃣ 源码剖析之工程化(一):项目概览.package.json.npm script 2️⃣ 源码剖析之工程化(二):项目构建.MD解析 3️⃣ 源码剖析之工程化(三):打包配置 本系列文章主要通过解析element项目源码,从结构.功能.源码方面逐一解析,学习其模块化.组件化.规范化.自动化等多维度优秀实践.主要内容包含项目结构.npm script.项目构建.文档解析.打包配置.发布部署等. 本文是第三篇,介绍项目的…