首页 > 其他分享 >element 初始化组件功能

element 初始化组件功能

时间:2023-03-28 19:32:56浏览次数:51  
标签:初始化 const .. index componentname element 组件 path

前言

这篇文章学习element组件库是如何初始化组件的。

资源:

源码

入口文件

找到用于初始化组件的脚本,位置如图:

image.png

开始

脚本的开始引用了一些文件,说明了脚本所要用到的工具都有那些。

'use strict';

console.log();
process.on('exit', () => {
  console.log();
});

if (!process.argv[2]) {
  console.error('[组件名]必填 - Please enter new component name');
  process.exit(1);
}

// 处理文件和目录路径
const path = require('path');
// 内置的 Node.js 模块,它提供文件系统操作,比如对文件系统的读写。
const fs = require('fs');
// 用于文本保存
const fileSave = require('file-save');
// 这是一个将字符串转换为 upperCamelcase 的库
const uppercamelcase = require('uppercamelcase');

const componentname = process.argv[2];
const chineseName = process.argv[3] || componentname;
const ComponentName = uppercamelcase(componentname);
const PackagePath = path.resolve(__dirname, '../../packages', componentname);

该脚本首先使用 process 对象的 on 方法注册一个回调函数,以便在进程退出时执行。回调函数将一个空行记录到控制台。

然后,脚本检查第二个命令行参数(process.argv [2])是否为真。如果它不是真值,那么脚本将记录一条错误消息,并使用非零退出代码退出进程(指示一个错误)。

然后,脚本声明一些变量:

  • componentname 设置为第二个命令行参数(组件名)。
  • chineseName 设置为第三个命令行参数(组件的中文名称) ,如果没有提供第三个参数,则设置为组件名称。
  • 组件名设置为使用 upperCamelCase 库将组件名转换为 UpperCamelCase 的结果。
  • PackagePath 设置为包目录的路径,后跟组件名。

文件列表

const Files = [
  {
    filename: 'index.js',
    content: `import ${ComponentName} from './src/main';
    ... 省略部分内容
    `
   },
   
   // ... 
 ]

之后脚本定义了一个Files变量,这个变量存储了需要添加或者需要修改的文件列表,同时也指示了添加或者修改的内容是什么。

那么具体都会修改那些文件呢:

  • index.js
  • 4个说明文档(zh-CN、en-US、es、fr-FR)
  • 测试文件 (/test/unit/specs)
  • 主题文件 (theme-chalk/src)
  • 类型文件

添加到 components.json

// 添加到 components.json
const componentsFile = require('../../components.json');
if (componentsFile[componentname]) {
  console.error(`${componentname} 已存在.`);
  process.exit(1);
}
componentsFile[componentname] = `./packages/${componentname}/index.js`;
fileSave(path.join(__dirname, '../../components.json'))
  .write(JSON.stringify(componentsFile, null, '  '), 'utf8')
  .end('\n');

检查组件名称的对象属性是否已经存在于 componentsFile 对象中。如果存在,脚本将记录一条错误消息,并使用非零退出代码退出进程。

如果组件不存在于 ComponentsFile 中,脚本将在对象上设置一个新属性,其中包含组件的名称和到达组件主入口点的路径的值(./package/${ Component entname }/index.js).

最后,脚本使用文件保存库将修改后的 ComponentsFile 对象写入 Components.json 文件,该文件采用缩进格式,并在文件末尾使用换行符。

其他文件的添加

// 添加到 index.scss
const sassPath = path.join(__dirname, '../../packages/theme-chalk/src/index.scss');
const sassImportText = `${fs.readFileSync(sassPath)}@import "./${componentname}.scss";`;
fileSave(sassPath)
  .write(sassImportText, 'utf8')
  .end('\n');

// 添加到 element-ui.d.ts
const elementTsPath = path.join(__dirname, '../../types/element-ui.d.ts');

let elementTsText = `${fs.readFileSync(elementTsPath)}
/** ${ComponentName} Component */
export class ${ComponentName} extends El${ComponentName} {}`;

const index = elementTsText.indexOf('export') - 1;
const importString = `import { El${ComponentName} } from './${componentname}'`;

elementTsText = elementTsText.slice(0, index) + importString + '\n' + elementTsText.slice(index);

fileSave(elementTsPath)
  .write(elementTsText, 'utf8')
  .end('\n');
  
// 创建 package
Files.forEach(file => {
  fileSave(path.join(PackagePath, file.filename))
    .write(file.content, 'utf8')
    .end('\n');
});

// 添加到 nav.config.json
const navConfigFile = require('../../examples/nav.config.json');

Object.keys(navConfigFile).forEach(lang => {
  let groups = navConfigFile[lang][4].groups;
  groups[groups.length - 1].list.push({
    path: `/${componentname}`,
    title: lang === 'zh-CN' && componentname !== chineseName
      ? `${ComponentName} ${chineseName}`
      : ComponentName
  });
});

fileSave(path.join(__dirname, '../../examples/nav.config.json'))
  .write(JSON.stringify(navConfigFile, null, '  '), 'utf8')
  .end('\n');

console.log('DONE!');

之后的代码将修改 index.scss 与 element-ui.d.ts,创建 package,修改nav.config.json,使用的方式也和上述相同。

总结

组件初始化脚本,很大程度上提高了开发效率,避免了程序员们将精力浪费在做重复的事情上,在我们日常的开发中也可尝试写一些这样的脚本。

标签:初始化,const,..,index,componentname,element,组件,path
From: https://blog.51cto.com/codeniu/6155256

相关文章

  • vue 软键盘组件封装
    场景和需求1软键盘固定2多输入框共用一个组件,聚焦切换时操作对象自动切换3根据光标在输入框的位置进行相应的输入和删除操作4点击软键盘时保存输入框光标活跃5输......
  • 第四部分:Spdlog日志库的核心组件分析-logger
    Spdlog是一个快速且可扩展的C++日志库,它支持多线程和异步日志记录。在本文中,我们将分析Spdlog日志库的核心代码,探究其实现原理和代码结构。Spdlog的基本架构上一篇文章介......
  • Android开发-Android常用组件-Button按钮
    4.3 Button(按钮)Button控件继承TextView,拥有TextView的属性。StateListDrawable简介StateListDrawable是Drawable资源的一种,可以根据不同的状态,设置不同的图片......
  • vue全家桶进阶之路23:Element UI
    ElementUI是一套基于Vue.js的组件库,它提供了一系列常用的UI组件,包括表单、弹窗、布局、导航等等。ElementUI的设计风格简洁、易用、美观,且易于定制。ElementUI......
  • Vue子组件向父组件传值(this.$emit()方法)
    子组件使用this.$emit()向父组件传值首先必须在父组件中引用子组件,然后实现传值第一步在父组件中引入子组件 importUnitByPurchaseAddOrUpdatefrom'@views/module......
  • 第七章 工程化 - 实例体验 - 基于 vue框架 开发一个完整的组件库 一
    基于vue框架开发一个完整的组件库来体验前端工程化的魅力对一个组件库的开发来全面认识熟悉前端工程化的配置,系统的理解工程化中各个工具所起到的作用,并且将其最终可......
  • 第八章 工程化 - 实例体验 - 基于 vue框架 开发一个完整的组件库 二
    基础Monorepo环境建设包名选择与注册1、给组件库命名=>最终会发布到npm.js仓库2、查看组件库的命名是否可注册方法npmviewpackage-nameversion如......
  • libx11遍历窗体上所有组件
    libx11遍历窗体上所有组件ANSWER想要遍历窗体上的所有组件,需要先获取窗体的ID,然后通过XQueryTree函数来获取窗体的子组件ID列表。可以通过以下步骤来实现:获取窗体I......
  • Element-UI el-upload组件,上传失败,但是依然显示文件列表
    问题描述最近在使用element-ui的el-upload组件,发现一个问题,就是我在上传文件过程中,上传失败了,文件列表仍然展示该文件。解决办法上传成功on-success回调方法中//除......
  • 组件之间的数据共享
    组件之间的数据共享:一、父组件传递给子组件①App.vuetemplate给子组件绑定值<Left:msg="message":user="userinfo"></Left>script声明需要发送的数据data(){......