亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

element如何初始化組件功能詳解

 更新時(shí)間:2022年12月21日 08:36:17   作者:codeniu  
Element UI是一套基于Vue的桌面端組件庫(kù),封裝好了很多常用的UI組件,下面這篇文章主要給大家介紹了關(guān)于element如何初始化組件功能的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),需要的朋友可以參考下

前言

上篇文章學(xué)習(xí)了 tdesign-vue 初始化組件的方式,這篇文章學(xué)習(xí)一下element組件庫(kù)是如何初始化組件的。

資源:

源碼

入口文件

找到用于初始化組件的腳本,位置如圖:

開始

腳本的開始引用了一些文件,說明了腳本所要用到的工具都有那些。

'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');
// 內(nèi)置的 Node.js 模塊,它提供文件系統(tǒng)操作,比如對(duì)文件系統(tǒng)的讀寫。
const fs = require('fs');
// 用于文本保存
const fileSave = require('file-save');
// 這是一個(gè)將字符串轉(zhuǎn)換為 upperCamelcase 的庫(kù)
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 對(duì)象的 on 方法注冊(cè)一個(gè)回調(diào)函數(shù),以便在進(jìn)程退出時(shí)執(zhí)行。回調(diào)函數(shù)將一個(gè)空行記錄到控制臺(tái)。

然后,腳本檢查第二個(gè)命令行參數(shù)(process.argv [2])是否為真。如果它不是真值,那么腳本將記錄一條錯(cuò)誤消息,并使用非零退出代碼退出進(jìn)程(指示一個(gè)錯(cuò)誤)。

然后,腳本聲明一些變量:

  • componentname 設(shè)置為第二個(gè)命令行參數(shù)(組件名)。
  • chineseName 設(shè)置為第三個(gè)命令行參數(shù)(組件的中文名稱) ,如果沒有提供第三個(gè)參數(shù),則設(shè)置為組件名稱。
  • 組件名設(shè)置為使用 upperCamelCase 庫(kù)將組件名轉(zhuǎn)換為 UpperCamelCase 的結(jié)果。
  • PackagePath 設(shè)置為包目錄的路徑,后跟組件名。

文件列表

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

之后腳本定義了一個(gè)Files變量,這個(gè)變量存儲(chǔ)了需要添加或者需要修改的文件列表,同時(shí)也指示了添加或者修改的內(nèi)容是什么。

那么具體都會(huì)修改那些文件呢:

  • index.js
  • 4個(gè)說明文檔(zh-CN、en-US、es、fr-FR)
  • 測(cè)試文件 (/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');

檢查組件名稱的對(duì)象屬性是否已經(jīng)存在于 componentsFile 對(duì)象中。如果存在,腳本將記錄一條錯(cuò)誤消息,并使用非零退出代碼退出進(jìn)程。

如果組件不存在于 ComponentsFile 中,腳本將在對(duì)象上設(shè)置一個(gè)新屬性,其中包含組件的名稱和到達(dá)組件主入口點(diǎn)的路徑的值(./package/${ Component entname }/index.js).

最后,腳本使用文件保存庫(kù)將修改后的 ComponentsFile 對(duì)象寫入 Components.json 文件,該文件采用縮進(jìn)格式,并在文件末尾使用換行符。

其他文件的添加

// 添加到 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');
  
// 創(chuàng)建 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,創(chuàng)建 package,修改nav.config.json,使用的方式也和上述相同。

總結(jié)

組件初始化腳本,很大程度上提高了開發(fā)效率,避免了程序員們將精力浪費(fèi)在做重復(fù)的事情上,在我們?nèi)粘5拈_發(fā)中也可嘗試寫一些這樣的腳本。

到此這篇關(guān)于element如何初始化組件功能的文章就介紹到這了,更多相關(guān)element初始化組件內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Vue源碼學(xué)習(xí)之關(guān)于對(duì)Array的數(shù)據(jù)偵聽實(shí)現(xiàn)

    Vue源碼學(xué)習(xí)之關(guān)于對(duì)Array的數(shù)據(jù)偵聽實(shí)現(xiàn)

    這篇文章主要介紹了Vue源碼學(xué)習(xí)之關(guān)于對(duì)Array的數(shù)據(jù)偵聽實(shí)現(xiàn),Vue使用了一個(gè)方式來實(shí)現(xiàn)Array類型的監(jiān)測(cè)就是攔截器,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-04-04
  • Vue中的v-cloak使用解讀

    Vue中的v-cloak使用解讀

    本篇文章主要介紹了Vue中的v-cloak使用解讀,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2017-03-03
  • vue-cropper組件實(shí)現(xiàn)圖片切割上傳

    vue-cropper組件實(shí)現(xiàn)圖片切割上傳

    這篇文章主要為大家詳細(xì)介紹了vue-cropper組件實(shí)現(xiàn)圖片切割上傳,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-05-05
  • element el-tree組件的動(dòng)態(tài)加載、新增、更新節(jié)點(diǎn)的實(shí)現(xiàn)

    element el-tree組件的動(dòng)態(tài)加載、新增、更新節(jié)點(diǎn)的實(shí)現(xiàn)

    這篇文章主要介紹了element el-tree組件的動(dòng)態(tài)加載、新增、更新節(jié)點(diǎn)的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-02-02
  • Vue利用computed配合watch實(shí)現(xiàn)監(jiān)聽多個(gè)屬性的變化

    Vue利用computed配合watch實(shí)現(xiàn)監(jiān)聽多個(gè)屬性的變化

    這篇文章主要給大家介紹了在Vue中巧用computed配合watch實(shí)現(xiàn)監(jiān)聽多個(gè)屬性的變化的方法,文中有詳細(xì)的代碼示例供大家參考,具有一定的參考價(jià)值,需要的朋友可以參考下
    2023-10-10
  • Vue路由對(duì)象屬性 .meta $route.matched詳解

    Vue路由對(duì)象屬性 .meta $route.matched詳解

    今天小編就為大家分享一篇Vue路由對(duì)象屬性 .meta $route.matched詳解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2019-11-11
  • vue.js實(shí)現(xiàn)只能輸入數(shù)字的輸入框

    vue.js實(shí)現(xiàn)只能輸入數(shù)字的輸入框

    這篇文章主要為大家詳細(xì)介紹了vue.js實(shí)現(xiàn)只能輸入數(shù)字的輸入框,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-10-10
  • vue3+ts+vite2項(xiàng)目實(shí)戰(zhàn)踩坑記錄

    vue3+ts+vite2項(xiàng)目實(shí)戰(zhàn)踩坑記錄

    最近嘗試上手Vue3+TS+Vite,對(duì)比起Vue2有些不適應(yīng),但還是真香,下面這篇文章主要給大家介紹了關(guān)于vue3+ts+vite2項(xiàng)目的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2022-09-09
  • Vue.js展示AJAX數(shù)據(jù)簡(jiǎn)單示例講解

    Vue.js展示AJAX數(shù)據(jù)簡(jiǎn)單示例講解

    當(dāng)通過AJAX方式取回?cái)?shù)據(jù)后,使用vue.js可以完美地按一定邏輯在頁(yè)面上的展示數(shù)據(jù),代碼簡(jiǎn)單、優(yōu)美、自然,而且便于與在用的頁(yè)面框架集成,本文給大家介紹Vue.js展示AJAX數(shù)據(jù)簡(jiǎn)單示例
    2017-03-03
  • Vue2?中自定義圖片懶加載指令?v-lazy實(shí)例詳解

    Vue2?中自定義圖片懶加載指令?v-lazy實(shí)例詳解

    這篇文章主要為大家介紹了Vue2?中自定義圖片懶加載指令?v-lazy實(shí)例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-09-09

最新評(píng)論