当前位置: 首页 > news >正文

组件库开发

组件库开发

环境搭建

menorepo

  • pnpm
  • pnpm-workspace
  • lerna 7.4.2 (已全局安装lerna)

1、初始化

1.1 新建项目目录root

1.2 在目录root使用pnpm初始化packages.json文件,新建 pnpm-workspace.yaml文件, packages/文件夹

pnpm-workspace.yaml有这个文件表示开启工作区。

文件内容如下:

// root/pnpm-workspace.yamlpackages:- "packages/*"
// root/lerna.json{"version": "0.0.0","npmClient": "pnpm"
}

1.3 root/packages/文件夹中新增子项目,使用lerna create <button>创建button子项目。

​ 或直接新建对应文件夹以及其中的文件…

使用lerna create <button>创建的button子项目内容如下

root/||packages/||button/|__test__/  测试文件存放|src/  项目代码|index.vue|index.js 入口文件|packages.json|READEME.md

root/ packages/ button/ src/ index.vue 文件写入内容

<template><h1>this button component 123</h1>
</template><script>
export default {name: 'ls-button',setup() {}
}
</script>

root/ packages/ button/ index.js 文件写入内容

import Button from './src/index.vue'Button.install = function (app) {app.component(Button.name, Button)
}export default Button

导出该项目中的各组件。

root/ packages/ button/ packages.json 文件写入内容

{"name": "@liindata/ls-button",  // 注意这里的名字,下边要用的"version": "0.0.0","description": "> TODO: description","author": "zhangxm <zxumei.com>","homepage": "","license": "ISC","main": "index.js","directories": {"lib": "src","test": "__tests__"},"files": ["src"],"scripts": {"test": "node ./__tests__/button.test.js"}
}

1.4 新建 root/play/文件夹。这里用来启动服务,来测试组件或在这里编写组件库的示例文档等等等等

这里使用 vite 来配置开发环境

root/play/|src/|App.vue|main.js|index.html|vite.config.js 

root/ play/ src/ App.vue 文件写入内容

<template><h1>monorepo demo 1</h1><lsbutton></lsbutton>
</template>
<script setup>import Lsbutton from '@liindata/ls-button' // 这里引入我的</script>

root/ play/ main.js 文件写入内容

import {createApp} from 'vue'
import App from './App.vue'const app = createApp(App)app.mount('#app')

root/ play/ vite.config.js 文件写入内容

import { defineConfig } from 'vite'
import vue from '@vitejs/plugin-vue'export default defineConfig({plugins: [vue()]
})

这时候准备工作已经ok!

2、依赖安装

经过第一步,肯定有很多疑问,比如使用了 vue、vite 但没有引入。

这里建议思考一下都要安装那些依赖,以及如何启动vite

2.1 安装依赖

安装 vite 
pnpm add vite -w
pnpm add @vitejs/plugin-vue -w -D
安装 vue
pnpm add vue -w

进入root/packages/button/中 执行命令, 把button 包软链到根目录。以便其它包使用…

pnpm link --dit ../../

执行后,在根目录 root/package.json 中

会自动添加 "@liindata/ls-button": "link:D:/work/liindata-ui-pnpm/packages/button"

完整内容如下。

{"name": "@liindata/root","scripts": {"play": "vite serve ./play" 这里配置root/play 为根目录启动vite},"dependencies": {"@liindata/ls-button": "link:D:/work/liindata-ui-pnpm/packages/button","lerna": "7.4.1","vue": "^3.3.7"},"devDependencies": {"@vitejs/plugin-vue": "^4.4.0","vite": "^4.5.0"}
}

pendencies": {
“@liindata/ls-button”: “link:D:/work/liindata-ui-pnpm/packages/button”,
“lerna”: “7.4.1”,
“vue”: “^3.3.7”
},
“devDependencies”: {
“@vitejs/plugin-vue”: “^4.4.0”,
“vite”: “^4.5.0”
}
}

执行 pnpm play 即可启动vite
http://www.lryc.cn/news/215196.html

相关文章:

  • 【python基础】魔法参数*args, **kwargs的使用
  • Android Icon 添加水印 Python脚本
  • 选择Centos系统需不需要带SElinux?
  • 项目级asp.net框架的LIMS实验室管理系统源码
  • pthread 变量静态初始化 避免使用被销毁过的变量
  • 深度学习之基于ResNet18的神经网络水果分类系统
  • 并查集易错点
  • 车载网关产品解析(附:车载网关详细应用案例及部署流程)
  • 高校教务系统登录页面JS分析——天津大学
  • 68 内网安全-域横向PTHPTKPTT哈希票据传递
  • 【1】2023版密评算分工具
  • 人工智能常用网站
  • OpenLayers实战,OpenLayers结合下拉菜单实现城市切换,动态切换城市边界到地图视图视角范围内
  • UE5 日记(人物连招:蒙太奇动画通知(含视频链接))
  • 葡萄酒是如何从葡萄园到你的酒杯的?
  • Oracle Exadata X7-2掉电宕机导致集群无法启动处理过程
  • 锐捷RG-EW1200G登录绕过漏洞复现
  • Python之循环语句
  • python中使用websocket调用、获取、保存大模型API
  • Linux的账号管理
  • 优优嗨聚集团:医保新政来袭,乙类OTC、保健品或将退出医保舞台,影响几何?
  • ubuntu安装pandora-gpt
  • PHP校验身份证号是否正确
  • [C++ ]:5.类和对象中(运算符重载补充)+ 类和对象下(初始化列表)
  • D. Doremy‘s Connecting Plan Codeforces Round 906 (Div. 2)
  • Prometheus+Grafana
  • CoCa论文笔记
  • uniapp 微信小程ios端键盘弹起后导致页面无法滚动
  • 三维模型优势在哪里?如何提升产品自身商业价值?
  • WheatA 轻量级生态数据软件