创建UI组件库后上传NPM

news2025/1/25 18:37:51

上篇已经讲了如何创建自己的组件库,这篇讲怎么上传npm后,可以下载使用

1.首先看下组件的文件结构

 在index.js中要写上每个组件可以按需引用的条件

import Button from "./src/button";

Button.install = function(Vue) {
  Vue.component(Button.name, Button);
};

export default Button;

2.然后这些组件要有个总的入口index.js

import Row from "./row/index.js";
import Col from "./col/index.js";
import Button from "./button/index.js";

const components = [
  Row,
  Col,
  Button
];

const install = Vue => {
  // 判断是否安装
  if (install.installed) return
  components.forEach(component => {
    Vue.component(component.name, component);
  });
};

// 判断是否是直接引入文件,如果是,就不用调用Vue.use()
if (typeof window !== "undefined" && window.Vue) {
  install(window.Vue);
}

export default {
  version: require('../package.json').version,
  install,
  Row,
  Col,
  Button
};

3.在设置下vue.config.js

const { defineConfig } = require("@vue/cli-service");
const MiniCssExtractPlugin = require("mini-css-extract-plugin");
const path = require("path");
module.exports = defineConfig({
  transpileDependencies: true,
  //解决build打包的时候 dist文件里面css、js、img路径错误错误的问题
  publicPath: "./",
  outputDir: "dist",
  assetsDir: "public",
  pages: {
    index: {
      entry: "examples/main.js",
      template: "public/index.html",
      filename: "index.html",
    },
  },
  // 扩展 webpack 配置, 使 packages 加入编译
  chainWebpack: (config) => {
    // 配置js和babel-loader
    config.module
      .rule("js")
      .include.add(path.resolve(__dirname, "packages"))
      .end()
      .use("label")
      .loader("babel-loader")
      .tap((options) => {
        // 修改它的选项
        return options;
      });
    // 配置自定义md-loader
    config.module
      .rule("md-loader")
      .test(/\.md$/)
      .use("vue-loader")
      .loader("vue-loader")
      .end()
      .use("md-loader")
      .loader(path.join(__dirname, "./md-loader/index.js"))
      .end();
  },
  // css: {
  //   extract: {
  //     // filename: "theme-chalk.css",
  //     // chunkFilename: "theme-chalk.[id].[contenthash].css",
  //   },
  //   // extract: true,
  // },
  configureWebpack: {
    resolve: {
      alias: {
        "@": path.resolve(__dirname, "examples"),
      },
    },
    output: {
      libraryExport: "default",
    },
    plugins: [
      new MiniCssExtractPlugin(
        {
        filename: "theme-chalk.css",
        }
      ),
    ],
  },
});

3.之后要设置下package.json

{
  "name": "", //这里是项目名称,要上传npm的话,不能和npm上已有的项目同名
  "version": "0.1.2", // 版本号,每次上传npm,版本号不能一样
  "private": false, // 是否私有,上传npm要开发为false
  "main": "", // lib打包后的路径
  "files": [
    "dist" // 发布时,包含的文件
  ],
  "author": {
    "name": "" // 作者
  },
  "scripts": {
    "serve": "vue-cli-service serve",
    "build": "vue-cli-service build",
    "lint": "vue-cli-service lint",
    "build:theme": "vue-cli-service build --target lib --name theme-chalk --entry packages/theme-chalk theme-chalk/index.scss",
    "lib": "vue-cli-service build --target lib packages/index.js" // lib打包只需要打包组件部分的代码,packages/index.js为组件部分的总入口
  },
......
......
}

4.npm run lib打包后,生成dist包

5.创建npm账户:访问 https://www.npmjs.com/signup 注册一个npm账户。这将允许你将你的项目上传到npm仓库。

6.登录npm账户:在你的命令行或终端中运行  npm login  命令 ,然后输入你的用户名、密码和电子邮件地址。

7.发布项目:在你的命令行或终端中,确保你处于项目的根目录,然后运行 npm publish 命令,将你的项目发布到npm仓库。

8.等待发布完成:如果一切顺利,你的项目将被上传到npm仓库,你应该能在你的npm账户的“已发布的包”部分看到它。

注意:在发布之前,请确保你的代码已经经过充分的测试,并遵循了发布开源软件的最佳实践。发布后,你可以使用npm version命令更新你的项目版本,并使用npm publish命令发布新版本。

查看npm包总下载量

使用npm-stat.com网站:

打开浏览器,访问 https://npm-stat.com/在页面上输入你想查询下载量的npm包名指定日期范围,可以查看该报告的下载数。将日期范围设置为“全部”以查看总下载量。

使用命令行工具npm包:npm-download-counts

  1. 首先确保你已经安装了Node.js和npm
  2. 打开终端或命令提示符,运行以下命令安装全局工具:

    npm install -g npm-download-counts

  3. 输入以下命令以查看特定npm包的总下载量(替换your-package-name为您要查询的包名):

    npm-download-counts -p your-package-name --total

  4. 等待结果显示在控制台中。

请注意,在使用这些方法查询下载量时,下载量可能略有不同,但总体上应该比较接近。总之,这就是如何查询npm包的总下载量。

上一篇:教你制作自己vue的组件库(仿ElementUI)

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/722313.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Tkinter_使用Progressbar创建和管理进度条

前言 Progressbar是Tkinter库中的一个小部件,用于创建和管理进度条。它可以在图形用户界面中显示任务的进度,并提供了多种样式和配置选项。 使用Progressbar,你可以按照固定或不确定的进度展示任务的进行状态。它可以显示任务完成的百分比&am…

“this“ 隐式具有类型 “any“,因为它没有类型注释。

在 tsconfig.json文件中 将 "noImplicitThis" 改为false "noImplicitThis": false,

工业互联网如何促进传统制造业的高效生产?

工业互联网,也称为工业物联网(IIoT),是指将联网设备和系统集成到传统制造流程中。它结合了传感器、数据分析、机器学习和自动化,以优化和提高制造各个方面的效率。工业互联网促进传统制造业高效生产的方式有&#xff1…

机器学习、监督学习、无监督学习基本概念

- 机器学习 机器学习是一门多领域交叉学科,涉及概率论、统计学、逼近论、凸分析、算法复杂度理论等多门学科。专门研究计算机怎样模拟或实现人类的学习行为,以获取新的知识或技能,重新组织已有的知识结构使之不断改善自身的性能。机器学习有…

Nginx反向代理提示413 Request Entity Too Large

请求返回的内容如下 <html> <head><title>413 Request Entity Too Large</title></head> <body> <center><h1>413 Request Entity Too Large</h1></center> <hr><center>nginx/1.20.2</center>…

BPM工作流引擎优势

什么是BPM工作流引擎&#xff1f; BPM工作流引擎是对企业的业务进行的管理&#xff0c;是一个开放性的平台。它是BPM与工作流引擎的结合。不仅能够实现所有OA的功能&#xff0c;还能够实现以端到端为中心的协作&#xff0c;重视企业从战略到执行自上而下的流程化、规范化管理&a…

用OpenCV创建一张类型为CV_8UC1的单通道随机灰度图像

#include <iostream> #include <opencv2/imgcodecs.hpp> #include <opencv2/opencv.hpp> #include <opencv2/highgui.hpp>int

差分进化算法(Differential Evolution,DE,附简单案例及详细matlab源码)

作者&#xff1a;非妃是公主 专栏&#xff1a;《智能优化算法》 博客地址&#xff1a;https://blog.csdn.net/myf_666 个性签&#xff1a;顺境不惰&#xff0c;逆境不馁&#xff0c;以心制境&#xff0c;万事可成。——曾国藩 文章目录 专栏推荐序一、概论二、差分进化算法&a…

7、Maxwell安装部署

1、Maxwell简介 1.1 Maxwell概述 Maxwell 是由美国Zendesk公司开源&#xff0c;用Java编写的MySQL变更数据抓取软件。它会实时监控Mysql数据库的数据变更操作&#xff08;包括insert、update、delete&#xff09;&#xff0c;并将变更数据以 JSON 格式发送给 Kafka、Kinesi等…

java项目之KTV点歌系统源码(ssm+jsp+mysql)

风定落花生&#xff0c;歌声逐流水&#xff0c;大家好我是风歌&#xff0c;混迹在java圈的辛苦码农。今天要和大家聊的是一款基于ssm的KTV点歌系统。项目源码以及部署相关请联系风歌&#xff0c;文末附上联系信息 。 &#x1f495;&#x1f495;作者&#xff1a;风歌&#xff0…

FPGA实验六:PWM信号调制器设计

目录 一、实验目的 二、设计要求 三、实验代码 1.顶层文件代码 2.仿真文件部分代码 3.系统工程文件 四、实验结果及分析 1、引脚锁定 2、仿真波形及分析 3、下载测试结果及分析 五、实验心得 一、实验目的 &#xff08;1&#xff09;掌握通信信号调制过程及实现原理…

Linux调优–I/O 调度器

Linux 的 I/O 调度器是一个以块式 I/O 访问存储卷的进程&#xff0c;有时也叫磁盘调度器。Linux I/O 调度器的工作机制是控制块设备的请求队列&#xff1a;确定队列中哪些 I/O 的优先级更高以及何时下发 I/O 到块设备&#xff0c;以此来减少磁盘寻道时间&#xff0c;从而提高系…

Android TEE可信计算环境与TrustZone基础

文章目录 前言可信计算环境TEE嵌入式安全现状现有的TEE分类TEE的应用场景TEE存在必要性 TrustZone移动端数据隔离安全/非安全世界CPU的特权等级TrustZone的结构CA与TA通信流程 TEE安全设计系统总线设计内存隔离机制安全启动机制安全通信机制 总结 前言 先引用 《可信计算&…

Java中规模软件开发实训——简单计算器制作

✨博主&#xff1a;命运之光 &#x1f338;专栏&#xff1a;Python星辰秘典 &#x1f433;专栏&#xff1a;web开发&#xff08;html css js&#xff09; ❤️专栏&#xff1a;Java经典程序设计 ☀️博主的其他文章&#xff1a;点击进入博主的主页 前言&#xff1a;在现代社会中…

springcloud+docker+k8s发布安装第三方插件脚本

Dockerfile 安装第三方依赖插件软件 &#xff0c;以及构建镜像 #基础镜像&#xff0c;如果本地仓库没有&#xff0c;会从远程仓库拉取 openjdk:8 FROM docker.io/centos:centos7 #暴露端口 EXPOSE 9311 # 避免centos中文乱码 ENV LANG en_US.utf8 #容器中创建工作目录 WORKDIR …

uni-app 从零开始第二章:hello world

一、新建项目 选择 默认模板&#xff0c;填写项目名&#xff0c;然后点击创建&#xff0c;我这里选择的是 vue3&#xff0c;大家自行选择&#xff0c;默认是2 二、 运行项目到各个平台 注意&#xff0c;这里需要提前开启 微信开发者工具的端口 同样的&#xff0c;需要将mumu模…

DAY39:贪心算法(七)根据身高重建队列(注意思路)+最少箭引爆气球(重叠区间)

文章目录 406.根据身高重建队列&#xff08;注意思路&#xff09;思路两个维度降序排序注意点 完整版vector容器插入相关复习为什么能直接根据ki数值插入ki位置的下标 时间复杂度vector-insert操作存在的问题链表优化版时间复杂度list和vector的插入与访问操作区别 452.最少弓箭…

使用SDWAN构建安全的混合WAN

使用SD-WAN构建安全的混合WAN SDWAN的爆炸已成为头条新闻了一年多。企业正在以惊人的速度采取SDWAN&#xff0c;不但可以为分支机构提供更灵活的连接和利用程序性能&#xff0c;而且可以跨全部网络提供。远程“超级用户”依托SDWAN(通过将小型台式机装备提供的安全性&#xff…

图像尺寸、仿射、透视变换

1、尺寸变换 1.1 图像差值原理 1.2 图像缩放、翻转、拼接 1.2.1 图像缩放 1.2.2 图像翻转 1.2.3 图像拼接 #include <iostream> #include <fstream> #include <opencv2/opencv.hpp>using namespace std; using namespace cv;int main() {Mat gray imread(…

spring boot项目如何自定义参数校验规则

spring boot项目对参数进行校验时&#xff0c;比如非空校验&#xff0c;可以直接用validation包里面自带的注解。但是对于一些复杂的参数校验&#xff0c;自带的校验规则无法满足要求&#xff0c;此时需要我们自定义参数校验规则。自定义校验规则和自带的规则实现方式一样&…