iis服务器助手广告广告
返回顶部
首页 > 资讯 > 前端开发 > JavaScript >element如何初始化组件功能详解
  • 954
分享到

element如何初始化组件功能详解

Element 组件element初始化组件element组件怎么安装 2022-12-21 09:12:24 954人浏览 八月长安
摘要

目录前言源码入口文件开始文件列表添加到 components.JSON其他文件的添加总结前言 上篇文章学习了 tdesign-Vue 初始化组件的方式,这篇文章学习一下element

前言

上篇文章学习了 tdesign-Vue 初始化组件的方式,这篇文章学习一下element组件库是如何初始化组件的。

资源:

  • 源码地址:element-analysis/new.js

源码

入口文件

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

开始

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

'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)}

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,使用的方式也和上述相同。

总结

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

到此这篇关于element如何初始化组件功能的文章就介绍到这了,更多相关element初始化组件内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

--结束END--

本文标题: element如何初始化组件功能详解

本文链接: https://www.lsjlt.com/news/175392.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • element如何初始化组件功能详解
    目录前言源码入口文件开始文件列表添加到 components.json其他文件的添加总结前言 上篇文章学习了 tdesign-vue 初始化组件的方式,这篇文章学习一下element...
    99+
    2022-12-21
    Element 组件 element初始化组件 element组件怎么安装
  • js如何初始化数组
    这篇文章给大家分享的是有关js如何初始化数组的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。初始化数组如果想要初始化一个指定长度的一维数组,并指定默认值,可以这样:const array =&n...
    99+
    2023-06-17
  • tdesignvue初始化组件源码解析
    目录前言源码脚本的入口创建目录内容写入删除目录删除导入语句总结前言 Tdesign-vue 是一由腾讯开源的 Vue.js 组件库。我们知道,这些大型的组件库业务覆盖面很广,基本都包...
    99+
    2022-12-21
    tdesign vue初始化组件 tdesign vue
  • java 中数组初始化实例详解
    1.数组初始化定义数组的方式:  int[] arr1; 或  int arr1[];数组初始化  通过上边的定义,我们只是得到了一个数组的引用。这时已经为引用分配了存储空间,但是还没有给数组对象本身分配任何空间。想要给数组对象分...
    99+
    2023-05-31
    java 数组 ava
  • Spring Bean是如何初始化的详解
    目录前言三级缓存doGetBeancreateBeandoCreateBeaninstantiateBeaninstantiateinstantiateClass注入Autowire...
    99+
    2024-04-02
  • C#中如何初始化数组
    这篇文章给大家介绍C#中如何初始化数组,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。C#数组初始化int[] iArray = new int[3]{2, 3, 4} 花括号被称为数组初始化器,数组初始化器只能在声明数...
    99+
    2023-06-17
  • java数组的初始化及操作详解
    Java数组的初始化及操作详解:数组的初始化是指在创建数组对象时为数组元素赋予初值。Java数组的初始化有以下几种方式:1. 静态初...
    99+
    2023-08-17
    Java
  • c语言数组如何初始化
    C语言数组可以通过以下几种方式进行初始化:1. 静态初始化:在定义数组时,直接给出初始值,并用大括号括起来。```cint arr[...
    99+
    2023-08-25
    c语言
  • ultraedit无法初始化ftp组件怎么解决
    这篇文章主要介绍了ultraedit无法初始化ftp组件怎么解决的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇ultraedit无法初始化ftp组件怎么解决文章都会有所收获,下面我们一起来看看吧。ultraed...
    99+
    2023-07-01
  • 如何在Java中初始化二维数组
    本篇文章给大家分享的是有关如何在Java中初始化二维数组,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。常用的java框架有哪些1.SpringMVC,Spring Web MV...
    99+
    2023-06-14
  • 如何在Java中静态初始化数组
    这期内容当中小编将会给大家带来有关如何在Java中静态初始化数组,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。Java可以用来干什么Java主要应用于:1. web开发;2. Android开发;3. 客...
    99+
    2023-06-14
  • Java数组实现动态初始化的实例详解
    概念 1、数组动态初始化只给定数组长度,系统默认初始化值。 2、格式 数据类型[] 数组名 = new 数据类型[数组长度]; int[] arr = new int[3];...
    99+
    2024-04-02
  • Java数组的静态初始化如何实现
    这篇文章主要介绍“Java数组的静态初始化如何实现”,在日常操作中,相信很多人在Java数组的静态初始化如何实现问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Java数组的静态初始化如何实现”的疑惑有所帮助!...
    99+
    2023-06-30
  • 如何在Golang中创建和初始化数组
    如何在Golang中创建和初始化数组 在Golang中,数组是一个固定长度的数据结构,用于存储相同类型的元素。数组的长度在创建时就确定了,无法动态改变。本文将介绍如何在Golang中创...
    99+
    2024-03-02
    初始化 golang 数组
  • Python如何创建二维数组和初始化
    一、Python用什么表达二维数组         严格意义上说,Python中并没有数组的概念,Python中表达一组数据有多种形式,例如list,tuple,set等数据结构都可以表达一组数,并且这组数也没有C和C++中数组的的同质限制...
    99+
    2023-09-21
    开发语言 python
  • word无法初始化visual如何解决
    这个问题可能是由于缺少必要的依赖项或出现了一些配置问题引起的。以下是一些可能的解决方法:1. 确保已正确安装了Microsoft V...
    99+
    2023-10-09
    word
  • windows ghub一直初始化如何解决
    这篇“windows ghub一直初始化如何解决”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“windows ghub一直初...
    99+
    2023-07-02
  • windows 0xv0000005初始化失败如何解决
    今天小编给大家分享一下windows 0xv0000005初始化失败如何解决的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。0...
    99+
    2023-07-01
  • Ubuntu配置文件系统如何初始化
    这篇文章主要介绍Ubuntu配置文件系统如何初始化,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!Ubuntu 配置文件系统初始化/etc/timezone 时区/etc/inetd.conf 超级进程Ubuntu 配...
    99+
    2023-06-17
  • win10重置初始化失败如何解决
    这篇文章主要介绍“win10重置初始化失败如何解决”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“win10重置初始化失败如何解决”文章能帮助大家解决问题。方法一: 1点选左下角“开始”按钮。2依次点...
    99+
    2023-07-01
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作