vxe-pc-ui
Version:
A vue based PC component library
328 lines (286 loc) • 10.5 kB
Markdown
# vxe-pc-ui
简体中文 | [繁體中文](README.zh-TW.md) | [English](README.en.md) | [日本語](README.ja-JP.md)
[](https://gitee.com/x-extends/vxe-pc-ui/stargazers)
[](https://www.npmjs.com/package/vxe-pc-ui)
[](https://github.com/x-extends/vxe-pc-ui/actions/workflows/webpack.yml)
[](https://npm-stat.com/charts.html?package=vxe-pc-ui)
[](https://github.com/x-extends/vxe-pc-ui/issues)
[](https://github.com/x-extends/vxe-pc-ui/issues?q=is%3Aissue+is%3Aclosed)
[](https://github.com/x-extends/vxe-pc-ui/pulls)
[](https://github.com/x-extends/vxe-pc-ui/pulls?q=is%3Apr+is%3Aclosed)
[](LICENSE)
一个基于 [vue](https://www.npmjs.com/package/vue) 的 PC 端组件库
* 设计理念
* 面向现代浏览器,高效的简洁 API 设计
* 按需加载
* 计划
* [x] ~~v1.0 基于 vue2.6+,停止维护 ~~
* [x] ~~v2.0 基于 vue2.6+,停止维护 ~~
* [x] v3.0 基于 vue2.6+,只支持现代浏览器,不支持 IE
* [x] v4.0 基于 vue3.2+,只支持现代浏览器,不支持 IE
* [ ] 计划功能:虚拟列表,支持百万级数据渲染
* [ ] 计划功能:虚拟表单,支持万级表单项渲染
* [ ] 计划功能:全功能表单可视化设计器
* [ ] 计划功能:全功能列表可视化设计器
* [ ] 计划功能:全功能流程图可视化设计器
* [ ] 计划功能:虚拟列表,支持千万级数据渲染
## 浏览器支持
 |  |  |  | 
--- | --- | --- | --- | --- |
80+ ✔ | 80+ ✔ | 90+ ✔ | 75+ ✔ | 10+ ✔ |
## 在线文档
👉 [组件文档](https://vxeui.com)
👉 [表格文档](https://vxetable.cn)
## QQ 交流群
该群供大家交流問題,如果群人数已满,将会不定期剔除不活跃的。


## 功能点
[👀 Vxe UI](https://vxeui.com)
* [x] alert 警告提示
* [x] anchor 锚点
* [x] anchor-link 锚点-链接
* [x] avatar 头像
* [x] badge 徽标
* [x] breadcrumb 面包屑
* [x] breadcrumb-item 面包屑-项
* [x] button 按钮
* [x] button-group 按钮组
* [x] calendar 日历
* [x] card 卡片
* [x] carousel 走马灯
* [x] carousel-item 走马灯 - 项
* [x] checkbox 复选框
* [x] checkbox-group 复选框-组
* [x] col 列
* [x] collapse 展开面板
* [x] collapse-pane 展开面板-容器
* [ ] color-picker 颜色选择器
* [x] countdown 倒计时
* [x] date-picker 日期选择器
* [x] drawer 抽屉
* [x] empty 空数据
* [ ] flow-design 流程设计器
* [ ] flow-view 流程设计器-视图渲染
* [x] form 表单
* [x] form-design 表单设计器
* [x] form-group 表单-分组
* [x] form-item 表单-项
* [x] form-view 表单设计器-视图渲染
* [x] icon 图标
* [x] icon-picker 图标选择
* [x] image 图片
* [x] image-group 图片组
* [x] image-preview 图片预览
* [x] input 输入框
* [x] layout-aside 页面布局-左侧
* [x] layout-body 页面布局-内容
* [x] layout-container 页面布局-容器
* [x] layout-footer 页面布局-页尾
* [x] layout-header 页面布局-页头
* [x] link 链接
* [x] list-design 列表设计器
* [x] list-view 列表设计器-视图渲染
* [x] list 虚拟列表
* [x] loading 加载中
* [x] menu 菜单
* [x] modal 模态窗口
* [x] number-input 数值输入框
* [x] optgroup 下拉框-分组项
* [x] option 下拉框-项
* [x] pager 分页
* [x] password-input 密码输入框
* [x] print 打印
* [x] print-page-break 分页打印
* [x] pulldown 下拉容器
* [x] radio 单选框
* [x] radio-button 单选框-按钮
* [x] radio-group 单选框-组
* [x] rate 评分
* [x] result 结果
* [x] row 行
* [x] select 下拉框
* [x] spilt 分割面板
* [x] spilt-pane 分割面板-面板
* [x] slider 滑块
* [ ] steps 步骤条
* [x] switch 开关
* [x] tab-pane 页签-容器
* [x] tabs 页签
* [x] text-ellipsis 多行文本溢出
* [x] table-select 表格下拉框
* [x] textarea 文本域
* [x] tip 提示
* [x] tooltip 文字提示
* [x] tree 树形组件
* [x] tree-select 树形下拉框
* [x] upload 附件上传
* [x] watermark 水印
[👀 Vxe Table](https://vxetable.cn)
* [x] table 表格-基础表格
* [x] column 表格-列
* [x] colgroup 表格-分组列
* [x] toolbar 表格-工具栏
* [x] grid 表格-配置式
## 安装
```shell
npm install vxe-pc-ui
```
```javascript
// ...
import VxeUI from 'vxe-pc-ui'
import 'vxe-pc-ui/lib/style.css'
// ...
// ...
import VxeTable from 'vxe-table'
import 'vxe-table/lib/style.css'
// ...
createApp(App).use(VxeUI).use(VxeTable).mount('#app')
```
### CDN
使用第三方 CDN 方式记得锁定版本号,避免受到非兼容性更新的影响
***不建议将第三方的 CDN 地址用于正式环境,因为该连接随时都可能会失效***
```HTML
<html>
<head>
<meta charset="utf-8">
<meta http-equiv="Cache-Control" content="no-cache, no-store, must-revalidate">
<meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">
<!-- style -->
<link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/vxe-pc-ui@4/lib/style.css">
<link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/vxe-table@4/lib/style.css">
<!-- vue -->
<script src="https://cdn.jsdelivr.net/npm/vue@3"></script>
<!-- table -->
<script src="https://cdn.jsdelivr.net/npm/xe-utils"></script>
<script src="https://cdn.jsdelivr.net/npm/vxe-pc-ui@4"></script>
<script src="https://cdn.jsdelivr.net/npm/vxe-table@4"></script>
</head>
<body>
<div id="app">
<div>
<vxe-form
:data="formData"
@submit="submitEvent">
<vxe-form-item title="名称" field="name" span="12" :item-render="{}">
<template #default="params">
<vxe-input v-model="formData.name"></vxe-input>
</template>
</vxe-form-item>
<vxe-form-item title="角色" field="role" span="12" :item-render="{}">
<template #default="params">
<vxe-input v-model="formData.role"></vxe-input>
</template>
</vxe-form-item>
<vxe-form-item title="年龄" field="age" span="12" :item-render="{}">
<template #default="params">
<vxe-input v-model="formData.age"></vxe-input>
</template>
</vxe-form-item>
<vxe-form-item align="center" span="24" :item-render="{}">
<template #default>
<vxe-button type="submit" status="primary">提交</vxe-button>
<vxe-button type="reset">重置</vxe-button>
</template>
</vxe-form-item>
</vxe-form>
</div>
</div>
<script>
(function () {
var App = {
data() {
return {
formData: {
name: '',
nickname: '',
sex: '',
role: ''
}
}
},
methods: {
submitEvent () {
VxeUI.modal.message({ content: '保存成功', status: 'success' })
}
}
}
Vue.createApp(App).use(VxeUI).use(VXETable).mount('#app')
})()
</script>
</body>
</html>
```
## 示例
```html
<template>
<div>
<vxe-form
:data="formData"
@submit="submitEvent">
<vxe-form-item title="名称" field="name" span="12" :item-render="{}">
<template #default="params">
<vxe-input v-model="formData.name"></vxe-input>
</template>
</vxe-form-item>
<vxe-form-item title="角色" field="role" span="12" :item-render="{}">
<template #default="params">
<vxe-input v-model="formData.role"></vxe-input>
</template>
</vxe-form-item>
<vxe-form-item title="年龄" field="age" span="12" :item-render="{}">
<template #default="params">
<vxe-input v-model="formData.age"></vxe-input>
</template>
</vxe-form-item>
<vxe-form-item align="center" span="24" :item-render="{}">
<template #default>
<vxe-button type="submit" status="primary">提交</vxe-button>
<vxe-button type="reset">重置</vxe-button>
</template>
</vxe-form-item>
</vxe-form>
</div>
</template>
<script>
export default {
data() {
return {
formData: {
name: '',
nickname: '',
sex: '',
role: ''
}
}
},
methods: {
submitEvent () {
VxeUI.modal.message({ content: '保存成功', status: 'success' })
}
}
}
</script>
```
## 运行项目
安装依赖
```shell
npm run update
```
启动本地调试
```shell
npm run serve
```
编译打包,生成编译后的目录:es,lib
```shell
npm run lib
```
## 贡献源码步骤
1. 如果是修复 bug,必须有示例的复现链接
2. 如果新功能,涉及代码风格、质量、还需有对应的示例页面
## 贡献者
Thank you to everyone who contributed to this project.
[](https://github.com/x-extends/vxe-pc-ui/graphs/contributors)
## 许可证
[MIT](LICENSE) © 2019-present, Xu Liangzhan