Naive Ultra:中后台 Naive UI 增强组件库

Naive Ultra:更优雅的 Naive UI 增强组件库

Naive Ultra 是基于 Naive UI 的增强型组件库,专为中后台场景设计,助力企业级应用高效开发。

项目简介

Naive Ultra 是在 Naive UI 基础上进行扩展和增强的组件库,旨在为开发者提供更丰富、更实用的业务组件和工具函数,帮助中后台项目快速落地。

  • 🌈 业务组件:涵盖表单、表格、操作栏等常用场景
  • 按需引入:支持 Vite/Webpack 自动导入
  • 🛠️ 类型支持:TypeScript 友好
  • 📦 开箱即用:与 Naive UI 无缝衔接

安装方式

推荐使用 pnpm 进行安装:

bash 复制代码
pnpm install --save naive-ultra

也可以使用 yarn:

bash 复制代码
yarn add naive-ultra

快速上手

全局引入

适合需要全量使用组件的场景:

js 复制代码
import NaiveUltra from 'naive-ultra'
import { createApp } from 'vue'
import App from './App.vue'

const app = createApp(App)
app.use(NaiveUltra)

按需引入(推荐)

推荐使用 unplugin-vue-componentsunplugin-auto-import 插件,实现组件和 API 的自动按需导入,极大减少打包体积。

安装插件
bash 复制代码
npm install -D unplugin-vue-components unplugin-auto-import
Vite 配置示例
ts 复制代码
import NaiveUltraImports from 'naive-ultra/imports'
import NaiveUltraResolver from 'naive-ultra/resolver'
import AutoImport from 'unplugin-auto-import/vite'
import Components from 'unplugin-vue-components/vite'
import { defineConfig } from 'vite'

export default defineConfig({
  plugins: [
    AutoImport({
      imports: [NaiveUltraImports()],
    }),
    Components({
      resolvers: [NaiveUltraResolver()],
    }),
  ],
})
Webpack 配置示例
js 复制代码
const NaiveUltraImports = require('naive-ultra/imports')
const NaiveUltraResolver = require('naive-ultra/resolver')
const AutoImport = require('unplugin-auto-import/webpack')
const Components = require('unplugin-vue-components/webpack')

module.exports = {
  plugins: [
    AutoImport({
      imports: [NaiveUltraImports()],
    }),
    Components({
      resolvers: [NaiveUltraResolver()],
    }),
  ],
}

组件示例

以表单为例,Naive Ultra 提供了更贴合业务的高级用法。下面的代码完全参考官方示例:

html 复制代码
<script lang="ts" setup>
import { defineForm } from 'naive-ultra'
import { ref } from 'vue'

const email = ref('')

const form = defineForm({
  brandNum: {
    type: 'input',
    props: {},
    placeholder: 'Please input brand number',
    value: '',
  },
  email: {
    type: 'input',
    placeholder: 'Please input email',
    value: email,
  },
  time: { type: 'date-picker' },
})
</script>

<template>
  <nu-form :is="form" />
  <pre>{{ JSON.stringify(form.dataTrans, null, 2) }}</pre>
</template>

适用场景

  • 需要更丰富业务组件的中后台项目
  • 希望提升开发效率、减少重复造轮子的团队
  • 追求极致按需引入、优化打包体积的 Vue3 项目

相关链接

结语

Naive Ultra 是我在前公司开发的集成框架,现在开源出来了,以前它帮了我很多,让我能在短时间快速重构一整个中后台系统。

另外,说实话,我是比较懒得写文章的,所以上面都是用 AI 生成的,怪不好意思的,建议直接去看官方文档。如果觉得项目不错,那就 Star 支持一下吧。

相关推荐
C澒4 小时前
微前端容器标准化:容器标准化演进
前端·架构
卖报的大地主4 小时前
Learn Claude Code Agent 开发 | 2、插拔式工具系统:扩展功能不修改核心循环
前端·chrome
qzhqbb5 小时前
Web 服务器(Nginx、Apache)
服务器·前端·nginx
天若有情6735 小时前
前端进阶必看:吃透这些高阶知识,告别CRUD,迈向高级前端工程师
前端·状态模式
coderYYY5 小时前
git push报错Authentication failed for ‘xxx’也不会弹要求输入用户名密码的最终解决方法
前端·git·gitee·github
l1t6 小时前
QWen 3.5plus总结的总结基准测试结果的正确方法
前端·数据库
kyriewen116 小时前
为什么我的代码在测试环境跑得好好的,一到用户电脑就崩?原来凶手躲在地址栏旁边
开发语言·前端·javascript·chrome·ecmascript·html5
小北方城市网6 小时前
JavaScript 实战 —— 实现一个简易的 TodoList(适合前端入门 / 进阶)
开发语言·前端·javascript
是上好佳佳佳呀6 小时前
【前端(二)】CSS 知识梳理:从编写位置到选择器优先级
前端·css
倾颜7 小时前
我是怎么把单 Tool Calling 升级成多 Tool Runtime 的
前端·后端·langchain