vue3新建组件库项目并上传到私库

创建vue3项目,步骤省略

nexus配置

访问 http://192.168.0.9:8081/

账号密码 admin Yanfabu01!

参考网址 https://www.jb51.net/javascript/3178205jj.htm

项目满足的条件

[tsconfig.json]中

添加"baseUrl": "."

[package.json]中

添加

"private": false,

"main": "/packages/index.js"

新建packages文件夹,编写组件

index.js代码

javascript 复制代码
import { version } from '../package.json'

import TyInput from './input/tyInput.vue'
import TyButton from "./button/tyButton.vue";

const components = [TyInput, TyButton]

const install = function(Vue, opts = {}) {
  components.forEach(component => {
    Vue.component(component.name, component)
  })
}

/* istanbul ignore if */
if (typeof window !== 'undefined' && window.Vue) {
  install(window.Vue)
}

export default {
  version,
  ...components,
  install
}

package.json中代码

javascript 复制代码
{
  "name": "tuyang-ui-plus",
  "version": "1.0.0"
}

建立组件tyButton,新建button文件夹,下面建立tyButton.vue和index.js

tyButton.vue代码

javascript 复制代码
<template>
  <div>
    <el-button type="primary">Primary</el-button>
  </div>
</template>
<script setup>
// 组件命名
defineOptions({name: 'TyButton'})
</script>

<style lang="scss" scoped></style>

index.js中代码

javascript 复制代码
// 导入组件
import TyButton from 'tyButton'

TyButton.install = function(Vue) {
  Vue.component('TyButton', TyButton)
}

export default TyButton

项目中测试组件是否好用,src文件下新建index.vue

javascript 复制代码
<template>
	<ty-button></ty-button>
</template>

<script setup lang="ts">
  import {ref} from "vue";
</script>

<style lang="scss" scoped>
</style>

组件库发布命令

设置本地仓库镜像源

npm config set registry http://192.168.0.9:8081/repository/tuyang-npm-group/

登录本地仓库

npm login --registry=http://192.168.0.9:8081/repository/tuyang-npm/

username:admin

password:Yanfabu01!

email:xxxxx

发布到本地仓库

npm publish --registry=http://192.168.0.9:8081/repository/tuyang-npm/

查看组件

浏览器访问 http://192.168.0.9:8081/

组件安装及使用

  1. npm install tuyang-ui-plus

2.main.js中引入

import tuYangUiPlus from 'tuyang-ui-plus'

app.use(tuYangUiPlus)

相关推荐
Jiaberrr2 小时前
Vue 3 中搭建菜单权限配置界面的详细指南
前端·javascript·vue.js·elementui
yzhSWJ3 小时前
Vue 3 中,将静态资源(如图片)转换为 URL
前端·javascript·vue.js
鱼樱前端4 小时前
基于Vue3+Ts+Vant的高级图片上传组件
前端·javascript·vue.js
Random_index5 小时前
#Vue篇:环境变量process.env.VUE_APP_API_URL&import.meta.env.VITE_API_URL
vue.js
周努力.5 小时前
关于Vue/React中Diffing算法以及key的作用
javascript·vue.js·react.js
lydxwj5 小时前
vue3自定义hooks遇到的问题
前端·javascript·vue.js
野生的程序媛5 小时前
重生之我在学Vue--第8天 Vue 3 UI 框架(Element Plus)
前端·vue.js·ui
前端付杰6 小时前
从Vue源码解锁位运算符:提升代码效率的秘诀
前端·javascript·vue.js
阿里巴巴P8资深技术专家7 小时前
使用vue3.0+electron搭建桌面应用并打包exe
前端·javascript·vue.js
刺客_Andy7 小时前
vue3 第二十九节 (vue3 事件循环之nextTick)
前端·vue.js