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)

相关推荐
暴走的小呆2 分钟前
Vue 2 中 Object 的变化侦测:从 getter/setter 到 Dep、Watcher、Observer
vue.js
英勇无比的消炎药13 分钟前
TinyVue v-auto-tip: 文本超长自动提示的优雅方案
vue.js
时光足迹3 小时前
腾讯云 TRTC UniApp SDK 从入门到上线
前端·vue.js·uni-app
时光足迹3 小时前
uni-app 里把加密视频嵌入页面播放?我分析了 4 种方案,只有 1 种接近完美
前端·vue.js·uni-app
时光足迹3 小时前
JPush UniApp UTS 插件完全参考手册:API、事件与厂商通道一网打尽
vue.js·ios·uni-app
时光足迹3 小时前
极光推送全攻略(下):uni-app 代码实现与 iOS 排查实战
vue.js·ios·uni-app
疯狂的魔鬼4 小时前
一个"懂分寸"的文本省略组件是怎样炼成的
前端·vue.js·设计
裕波4 小时前
AI 正在重写应用开发。Vue 与 Vite,给出新的答案。
javascript·vue.js
妙码生花4 小时前
现代前端的极致性能 icon 加载方案(死磕成功版)
前端·vue.js·typescript
用户2136610035728 小时前
Vue2脚手架工程化与Axios集成
前端·vue.js