Vue3 & 详解 vue-cli 使用 --target lib 打包的方式

1. 什么是 lib

1.1 简介

在 vue-cli 使用 npm run build 打包项目后,默认会提供一个入口(通常是 index.html),然后引入一个 js 入口文件完成页面的渲染。
其实 vue-cli 还支持将项目作为一个库的方式来进行打包,这里需要借助 --target lib 命令 ,此命令会将入口文件打包成一个库吗,具体可参考官方解释
接下来我会逐步详解如何构建属于自己的库。

vite 也可以构建 lib 库,原理也是差不多的,这里不在赘述。

1.2 准备工作

这里我们采用 vue-cli 作为脚手架工具新建一个 vue-project 项目,

npm install -g @vue/cli 4.5.15
vue create vue-project

目录结构如图:
在这里插入图片描述

2. Vue-cli

2.1 准备工作

2.1.1 新建 vue-cli-lib-example 库,此项目是作为库用的

vue create vue-cli-lib-example

在这里插入图片描述
上面我只需保留这一部分,其它都可以删掉。

2.1.2 在 components 目录下新增以下文件,内容如下:
在这里插入图片描述
其中 components/index.js 文件负责导出 my-tip 组件

2.1.3 修改 main.js 文件
在这里插入图片描述
如图所知,这里分为 3 步骤:

  1. 引入了 index.js 文件(./components === ./components/index.js)
  2. 在 MyTip 组件(组件也是对象)中添加了 install 方法(重点)&
Vue 3使用Element UI,需要安装Element Plus这个版本来适配Vue 3项目。首先,你需要安装Element Plus,可以使用npm或yarn命令进行安装。 安装Element Plus: ``` npm install element-plus ``` 或者 ``` yarn add element-plus ``` 安装完成后,接下来你可以选择全局引入或按需引入Element Plus组件。 全局引入Element Plus: 在你的Vue 3项目的入口文件(通常是main.js)中,添加以下代码: ``` import { createApp } from 'vue' import ElementPlus from 'element-plus' import 'element-plus/lib/theme-chalk/index.css' const app = createApp(...) app.use(ElementPlus) app.mount('#app') ``` 按需引入Element Plus: 如果你希望只引入需要的组件,可以使用babel-plugin-component插件来实现按需引入。首先,安装插件: ``` npm install babel-plugin-component -D ``` 或者 ``` yarn add babel-plugin-component -D ``` 然后,在babel.config.js文件中添加以下配置: ``` module.exports = { presets: [ '@vue/cli-plugin-babel/preset' ], plugins: [ [ 'component', { libraryName: 'element-plus', styleLibraryName: 'theme-chalk' } ] ] } ``` 这样就可以按需引入Element Plus的组件了,例如: ``` import { ElButton, ElInput } from 'element-plus' ``` 以上就是在Vue 3使用Element Plus的步骤。你可以根据项目的需要选择全局引入或按需引入组件来使用Element Plus的UI组件。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *3* [Vue3项目中引入ElementUI使用详解](https://blog.csdn.net/m0_46309087/article/details/131277139)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}}] [.reference_item style="max-width: 50%"] - *2* [【vuevue3使用element ui](https://blog.csdn.net/qq_53966155/article/details/126144035)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

cookcyq

请作者喝杯暖暖的奶茶

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值