uview-pro 0.0.17 → 0.0.19

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (232) hide show
  1. package/changelog.md +283 -249
  2. package/components/u-action-sheet/types.ts +35 -35
  3. package/components/u-action-sheet/u-action-sheet.vue +160 -160
  4. package/components/u-alert-tips/types.ts +39 -39
  5. package/components/u-alert-tips/u-alert-tips.vue +212 -212
  6. package/components/u-avatar/types.ts +34 -34
  7. package/components/u-avatar/u-avatar.vue +193 -193
  8. package/components/u-avatar-cropper/types.ts +23 -23
  9. package/components/u-avatar-cropper/u-avatar-cropper.vue +286 -286
  10. package/components/u-avatar-cropper/weCropper.d.ts +62 -62
  11. package/components/u-avatar-cropper/weCropper.js +1253 -1253
  12. package/components/u-avatar-cropper/weCropper.ts +1255 -1255
  13. package/components/u-back-top/types.ts +39 -39
  14. package/components/u-back-top/u-back-top.vue +125 -125
  15. package/components/u-badge/types.ts +36 -36
  16. package/components/u-badge/u-badge.vue +165 -165
  17. package/components/u-button/types.ts +66 -66
  18. package/components/u-button/u-button.vue +554 -554
  19. package/components/u-calendar/types.ts +63 -63
  20. package/components/u-calendar/u-calendar.vue +592 -592
  21. package/components/u-car-keyboard/types.ts +12 -12
  22. package/components/u-car-keyboard/u-car-keyboard.vue +234 -234
  23. package/components/u-card/types.ts +59 -59
  24. package/components/u-card/u-card.vue +194 -194
  25. package/components/u-cell-group/types.ts +17 -17
  26. package/components/u-cell-group/u-cell-group.vue +50 -50
  27. package/components/u-cell-item/types.ts +54 -54
  28. package/components/u-cell-item/u-cell-item.vue +202 -202
  29. package/components/u-checkbox/types.ts +31 -31
  30. package/components/u-checkbox/u-checkbox.vue +267 -265
  31. package/components/u-checkbox-group/types.ts +32 -32
  32. package/components/u-checkbox-group/u-checkbox-group.vue +79 -79
  33. package/components/u-circle-progress/types.ts +52 -52
  34. package/components/u-circle-progress/u-circle-progress.vue +189 -189
  35. package/components/u-city-select/types.ts +20 -20
  36. package/components/u-city-select/u-city-select.vue +236 -236
  37. package/components/u-col/types.ts +30 -30
  38. package/components/u-col/u-col.vue +123 -123
  39. package/components/u-collapse/types.ts +31 -31
  40. package/components/u-collapse/u-collapse.vue +68 -68
  41. package/components/u-collapse-item/types.ts +25 -25
  42. package/components/u-collapse-item/u-collapse-item.vue +176 -176
  43. package/components/u-column-notice/types.ts +48 -48
  44. package/components/u-column-notice/u-column-notice.vue +176 -176
  45. package/components/u-count-down/types.ts +42 -42
  46. package/components/u-count-down/u-count-down.vue +258 -258
  47. package/components/u-count-to/types.ts +32 -32
  48. package/components/u-count-to/u-count-to.vue +241 -241
  49. package/components/u-divider/types.ts +31 -31
  50. package/components/u-divider/u-divider.vue +121 -121
  51. package/components/u-dropdown/types.ts +32 -32
  52. package/components/u-dropdown/u-dropdown.vue +289 -289
  53. package/components/u-dropdown-item/types.ts +27 -27
  54. package/components/u-dropdown-item/u-dropdown-item.vue +123 -123
  55. package/components/u-empty/types.ts +36 -36
  56. package/components/u-empty/u-empty.vue +88 -88
  57. package/components/u-field/types.ts +69 -69
  58. package/components/u-field/u-field.vue +354 -354
  59. package/components/u-full-screen/types.ts +14 -14
  60. package/components/u-full-screen/u-full-screen.vue +82 -82
  61. package/components/u-gap/types.ts +18 -18
  62. package/components/u-gap/u-gap.vue +40 -40
  63. package/components/u-grid/types.ts +19 -19
  64. package/components/u-grid/u-grid.vue +93 -93
  65. package/components/u-grid-item/types.ts +16 -16
  66. package/components/u-grid-item/u-grid-item.vue +130 -130
  67. package/components/u-icon/types.ts +62 -62
  68. package/components/u-icon/u-icon.vue +274 -274
  69. package/components/u-image/types.ts +51 -51
  70. package/components/u-image/u-image.vue +222 -222
  71. package/components/u-index-anchor/types.ts +16 -16
  72. package/components/u-index-anchor/u-index-anchor.vue +86 -86
  73. package/components/u-index-list/types.ts +43 -43
  74. package/components/u-index-list/u-index-list.vue +355 -355
  75. package/components/u-input/types.ts +140 -140
  76. package/components/u-input/u-input.vue +255 -255
  77. package/components/u-keyboard/types.ts +40 -40
  78. package/components/u-keyboard/u-keyboard.vue +158 -158
  79. package/components/u-lazy-load/types.ts +37 -37
  80. package/components/u-lazy-load/u-lazy-load.vue +233 -233
  81. package/components/u-line/types.ts +44 -44
  82. package/components/u-line/u-line.vue +59 -59
  83. package/components/u-line-progress/types.ts +58 -58
  84. package/components/u-line-progress/u-line-progress.vue +109 -109
  85. package/components/u-link/types.ts +43 -43
  86. package/components/u-link/u-link.vue +75 -75
  87. package/components/u-loading/types.ts +35 -35
  88. package/components/u-loading/u-loading.vue +90 -90
  89. package/components/u-loading-popup/types.ts +26 -26
  90. package/components/u-loading-popup/u-loading-popup.vue +239 -239
  91. package/components/u-loadmore/types.ts +79 -79
  92. package/components/u-loadmore/u-loadmore.vue +140 -140
  93. package/components/u-mask/types.ts +43 -43
  94. package/components/u-mask/u-mask.vue +106 -106
  95. package/components/u-message-input/types.ts +74 -74
  96. package/components/u-message-input/u-message-input.vue +255 -255
  97. package/components/u-modal/types.ts +118 -118
  98. package/components/u-modal/u-modal.vue +200 -200
  99. package/components/u-navbar/types.ts +103 -103
  100. package/components/u-navbar/u-navbar.vue +226 -226
  101. package/components/u-no-network/image.ts +2 -2
  102. package/components/u-no-network/types.ts +28 -28
  103. package/components/u-no-network/u-no-network.vue +290 -290
  104. package/components/u-notice-bar/types.ts +111 -111
  105. package/components/u-notice-bar/u-notice-bar.vue +174 -174
  106. package/components/u-number-box/types.ts +42 -42
  107. package/components/u-number-box/u-number-box.vue +312 -312
  108. package/components/u-number-keyboard/types.ts +26 -26
  109. package/components/u-number-keyboard/u-number-keyboard.vue +166 -166
  110. package/components/u-picker/types.ts +111 -111
  111. package/components/u-picker/u-picker.vue +637 -637
  112. package/components/u-popup/types.ts +59 -59
  113. package/components/u-popup/u-popup.vue +359 -359
  114. package/components/u-radio/types.ts +25 -25
  115. package/components/u-radio/u-radio.vue +258 -258
  116. package/components/u-radio-group/types.ts +29 -29
  117. package/components/u-radio-group/u-radio-group.vue +98 -98
  118. package/components/u-rate/types.ts +40 -40
  119. package/components/u-rate/u-rate.vue +234 -234
  120. package/components/u-read-more/types.ts +35 -35
  121. package/components/u-read-more/u-read-more.vue +150 -150
  122. package/components/u-row/types.ts +20 -20
  123. package/components/u-row/u-row.vue +87 -87
  124. package/components/u-row-notice/types.ts +39 -39
  125. package/components/u-row-notice/u-row-notice.vue +213 -213
  126. package/components/u-search/types.ts +53 -53
  127. package/components/u-search/u-search.vue +256 -256
  128. package/components/u-section/types.ts +32 -32
  129. package/components/u-section/u-section.vue +125 -125
  130. package/components/u-select/types.ts +43 -43
  131. package/components/u-select/u-select.vue +361 -361
  132. package/components/u-skeleton/types.ts +20 -20
  133. package/components/u-skeleton/u-skeleton.vue +205 -205
  134. package/components/u-slider/types.ts +32 -32
  135. package/components/u-slider/u-slider.vue +238 -238
  136. package/components/u-steps/types.ts +28 -28
  137. package/components/u-steps/u-steps.vue +160 -160
  138. package/components/u-sticky/types.ts +22 -22
  139. package/components/u-sticky/u-sticky.vue +159 -159
  140. package/components/u-subsection/types.ts +36 -36
  141. package/components/u-subsection/u-subsection.vue +328 -328
  142. package/components/u-swipe-action/types.ts +50 -50
  143. package/components/u-swipe-action/u-swipe-action.vue +253 -253
  144. package/components/u-swiper/types.ts +47 -47
  145. package/components/u-swiper/u-swiper.vue +266 -266
  146. package/components/u-switch/types.ts +28 -28
  147. package/components/u-switch/u-switch.vue +128 -128
  148. package/components/u-tabbar/types.ts +36 -36
  149. package/components/u-tabbar/u-tabbar.vue +280 -280
  150. package/components/u-table/types.ts +25 -25
  151. package/components/u-table/u-table.vue +55 -55
  152. package/components/u-tabs/types.ts +51 -51
  153. package/components/u-tabs/u-tabs.vue +284 -284
  154. package/components/u-tabs-swiper/types.ts +53 -53
  155. package/components/u-tabs-swiper/u-tabs-swiper.vue +379 -379
  156. package/components/u-tag/types.ts +37 -37
  157. package/components/u-tag/u-tag.vue +244 -244
  158. package/components/u-td/types.ts +12 -12
  159. package/components/u-td/u-td.vue +69 -69
  160. package/components/u-th/types.ts +12 -12
  161. package/components/u-th/u-th.vue +63 -63
  162. package/components/u-time-line/u-time-line.vue +39 -39
  163. package/components/u-time-line-item/types.ts +14 -14
  164. package/components/u-time-line-item/u-time-line-item.vue +78 -78
  165. package/components/u-toast/types.ts +36 -36
  166. package/components/u-toast/u-toast.vue +233 -233
  167. package/components/u-top-tips/types.ts +14 -14
  168. package/components/u-top-tips/u-top-tips.vue +113 -113
  169. package/components/u-tr/types.ts +8 -8
  170. package/components/u-tr/u-tr.vue +24 -24
  171. package/components/u-upload/types.ts +71 -71
  172. package/components/u-upload/u-upload.vue +545 -545
  173. package/components/u-verification-code/types.ts +22 -22
  174. package/components/u-verification-code/u-verification-code.vue +164 -164
  175. package/components/u-waterfall/types.ts +16 -16
  176. package/components/u-waterfall/u-waterfall.vue +175 -175
  177. package/iconfont.css +910 -910
  178. package/index.scss +22 -22
  179. package/index.ts +195 -202
  180. package/libs/config/config.ts +26 -26
  181. package/libs/config/zIndex.ts +37 -37
  182. package/libs/css/color.scss +155 -155
  183. package/libs/css/common.scss +175 -175
  184. package/libs/css/style.components.scss +6 -6
  185. package/libs/css/style.h5.scss +8 -8
  186. package/libs/css/style.mp.scss +72 -72
  187. package/libs/css/style.nvue.scss +2 -2
  188. package/libs/css/style.vue.scss +175 -175
  189. package/libs/function/$parent.ts +22 -22
  190. package/libs/function/addUnit.ts +13 -13
  191. package/libs/function/color.ts +36 -36
  192. package/libs/function/colorGradient.ts +125 -125
  193. package/libs/function/debounce.ts +28 -28
  194. package/libs/function/deepClone.ts +39 -39
  195. package/libs/function/deepMerge.ts +34 -34
  196. package/libs/function/getParent.ts +58 -58
  197. package/libs/function/getRect.ts +26 -26
  198. package/libs/function/guid.ts +42 -42
  199. package/libs/function/md5.ts +398 -398
  200. package/libs/function/parent.ts +21 -21
  201. package/libs/function/queryParams.ts +60 -60
  202. package/libs/function/random.ts +16 -16
  203. package/libs/function/randomArray.ts +11 -11
  204. package/libs/function/route.ts +118 -118
  205. package/libs/function/sys.ts +15 -15
  206. package/libs/function/test.ts +229 -229
  207. package/libs/function/throttle.ts +31 -31
  208. package/libs/function/timeFormat.ts +54 -54
  209. package/libs/function/timeFrom.ts +48 -48
  210. package/libs/function/toast.ts +14 -14
  211. package/libs/function/trim.ts +21 -21
  212. package/libs/function/type2icon.ts +36 -36
  213. package/libs/hooks/useEmitter.ts +77 -77
  214. package/libs/hooks/useParent.ts +29 -29
  215. package/libs/request/auto-http.ts +76 -76
  216. package/libs/request/index.ts +223 -237
  217. package/libs/store/index.ts +88 -88
  218. package/libs/util/async-validator.d.ts +62 -62
  219. package/libs/util/async-validator.js +1356 -1356
  220. package/libs/util/emitter.ts +112 -112
  221. package/libs/util/mitt.ts +118 -118
  222. package/libs/util/parent.ts +20 -20
  223. package/package.json +107 -107
  224. package/readme.md +231 -231
  225. package/theme.scss +38 -38
  226. package/types/components.d.ts +95 -95
  227. package/types/global.d.ts +221 -221
  228. package/types/ignore-errors.d.ts +30 -30
  229. package/types/index.d.ts +90 -90
  230. package/types/uni-app.d.ts +63 -63
  231. package/libs/request/uni-http.md +0 -156
  232. package/libs/request/uni-http.ts +0 -434
package/readme.md CHANGED
@@ -1,231 +1,231 @@
1
- <p align="center">
2
- <img alt="logo" src="https://ik.imagekit.io/anyup/uview-pro/common/logo.png" width="120" height="120" style="margin-bottom: 10px;">
3
- </p>
4
- <h3 align="center" style="margin: 30px 0 30px;font-weight: bold;font-size:40px;">uView Pro</h3>
5
- <h3 align="center">uni-app Vue3 多平台快速开发的 UI 框架</h3>
6
-
7
- [![star](https://gitee.com/anyup/uView-Pro/badge/star.svg)](https://gitee.com/anyup/uView-Pro)
8
- [![fork](https://gitee.com/anyup/uView-Pro/badge/fork.svg)](https://gitee.com/anyup/uView-Pro)
9
- [![stars](https://img.shields.io/github/stars/anyup/uView-Pro?style=flat-square&logo=GitHub)](https://github.com/anyup/uView-Pro)
10
- [![forks](https://img.shields.io/github/forks/anyup/uView-Pro?style=flat-square&logo=GitHub)](https://github.com/anyup/uView-Pro)
11
- [![issues](https://img.shields.io/github/issues/anyup/uView-Pro?style=flat-square&logo=GitHub)](https://github.com/anyup/uView-Pro/issues)
12
- [![npm version](https://img.shields.io/npm/v/uview-pro)](https://www.npmjs.com/package/uview-pro)
13
- [![Website](https://img.shields.io/badge/uView%20Pro-docs-blue?style=flat-square)](https://uview-pro.anyup.cn/)
14
- [![node version](https://img.shields.io/badge/node-%3E%3D18-green)](https://nodejs.org/)
15
- [![pnpm version](https://img.shields.io/badge/pnpm-%3E%3D7.30-green)](https://pnpm.io/)
16
- [![license](https://img.shields.io/github/license/anyup/uView-Pro?style=flat-square)](https://en.wikipedia.org/wiki/MIT_License)
17
-
18
- ## 说明
19
-
20
- `uView UI`,是 [uni-app](https://uniapp.dcloud.io/) 生态优秀的 UI 框架,全面的组件和便捷的工具会让您信手拈来,如鱼得水。
21
-
22
- `uView Pro`,是全面支持 Vue3.0、TypeScript 的 uni-app 生态框架,uView Pro 的基线版本是基于 uView 1.8.8 修改,使用 TypeScript 完全重构,目前已全面支持 uni-app Vue3.0。
23
-
24
- ## [官方文档:https://uview-pro.netlify.app/](https://uview-pro.netlify.app/)
25
-
26
- ## 特性
27
-
28
- - 兼容安卓,iOS,微信小程序,H5,QQ 小程序,百度小程序,支付宝小程序,头条小程序
29
- - 70+精选组件,功能丰富,多端兼容,让您快速集成,开箱即用
30
- - 众多贴心的 JS 利器,让您飞镖在手,召之即来,百步穿杨
31
- - 众多的常用页面和布局,让您专注逻辑,事半功倍
32
- - 详尽的文档支持,现代化的演示效果
33
- - 按需引入,精简打包体积
34
-
35
- ## 手机预览
36
-
37
- 您可以通过**微信**或**手机浏览器**扫描以下二维码,查看最佳的演示效果。
38
-
39
- <table class="table">
40
- <tr>
41
- <td><img src="https://ik.imagekit.io/anyup/images/social/qr_uview_pro_wx.jpg" width="200" height="200" ></td>
42
- <td><img src="https://ik.imagekit.io/anyup/images/social/qr_uview_pro_h5.png" width="200" height="200" ></td>
43
- <td><img src="https://ik.imagekit.io/anyup/images/social/qr_uview_pro_android.png" width="200" height="200" ></td>
44
- </tr>
45
- <tr>
46
- <td align="center"><strong>微信小程序</strong><br>(微信扫码)</td>
47
- <td align="center"><strong>H5</strong><br>(浏览器扫码)</td>
48
- <td align="center"><strong>Android</strong><br>(浏览器扫码)</td>
49
- </tr>
50
- </table>
51
-
52
- 运行示例工程,请[下载源码](https://github.com/anyup/uview-pro)后,在项目根目录执行以下命令:
53
-
54
- ```bash
55
- pnpm install
56
- pnpm dev
57
- ```
58
-
59
- ## 链接
60
-
61
- - [Github](https://github.com/anyup/uview-pro)
62
- - [Gitee](https://gitee.com/anyup/uview-pro)
63
- - [官方文档](https://uview-pro.netlify.app/)
64
- - [更新日志](https://github.com/anyup/uView-Pro/blob/master/src/uni_modules/uview-pro/changelog.md)
65
-
66
- ## 交流反馈
67
-
68
- `uView Pro` QQ 交流群: [点击进入](http://qm.qq.com/cgi-bin/qm/qr?_wv=1027&k=98nSVDldWEbDdq4lxiP4aL7uATfMSlI6&authKey=G2yQJ5MQiKzMldaxBsIfKt17NuJuUw8Fr6zdKLggc6NZXgw4BVbqkU2U3EE994yd&noverify=0&group_code=811732166)
69
-
70
- <table class="table">
71
- <tr>
72
- <td><img src="https://ik.imagekit.io/anyup/images/social/weixin-chat-2.png?updatedAt=1756355426929" width="250" height="345" ></td>
73
- <td><img src="https://ik.imagekit.io/anyup/images/social/qq-chat.png" width="250" height="345" ></td>
74
- </tr>
75
- <tr>
76
- <td align="center"><strong>微信群</strong><br></td>
77
- <td align="center"><strong>QQ群</strong><br></td>
78
- </tr>
79
- </table>
80
-
81
- ## 关于 PR
82
-
83
- 我们非常乐意接受各位的优质 PR,但在此之前我希望您了解 `uView Pro` 是一个需要兼容多个平台的(小程序、h5、iOS App、Android App)包括 nvue 页面、vue 页面。
84
-
85
- 所以希望在您修复 bug 并提交之前尽可能的去这些平台测试一下兼容性。最好能携带测试截图以方便审核。非常感谢!
86
-
87
- ## 安装配置
88
-
89
- `uView Pro` 支持 `npm` 和 `uni_modules` 两种主流安装方式,配置方式高度一致。无论采用哪种方式,均可通过 `easycom` 实现组件自动引入,极大提升开发效率。以下为统一的配置说明:
90
-
91
- ### 1. 安装 uView Pro
92
-
93
- - npm 安装:
94
-
95
- ```bash
96
- npm install uview-pro
97
- # 或
98
- yarn add uview-pro
99
- # 或
100
- pnpm add uview-pro
101
- ```
102
-
103
- - uni_modules 安装:
104
-
105
- 通过 HBuilderX 插件市场或手动下载,将 uView Pro 放入 `uni_modules` 目录。
106
-
107
- [插件市场:https://ext.dcloud.net.cn/plugin?id=24633](https://ext.dcloud.net.cn/plugin?id=24633)
108
-
109
- ### 2. 引入 uView Pro 主库
110
-
111
- 在 `main.ts` 中引入并注册 uView Pro:
112
-
113
- ```js
114
- import { createSSRApp } from 'vue';
115
- // npm 方式
116
- import uViewPro from 'uview-pro';
117
- // uni_modules 方式
118
- // import uViewPro from "@/uni_modules/uview-pro";
119
-
120
- export function createApp() {
121
- const app = createSSRApp(App);
122
- app.use(uViewPro);
123
- return {
124
- app
125
- };
126
- }
127
- ```
128
-
129
- ### 3. 引入全局样式
130
-
131
- 在 `uni.scss` 中引入主题样式:
132
-
133
- ```scss
134
- /* npm 方式 */
135
- @import 'uview-pro/theme.scss';
136
- /* uni_modules 方式 */
137
- /* @import "@/uni_modules/uview-pro/theme.scss"; */
138
- ```
139
-
140
- 在 `App.vue` 首行引入基础样式:
141
-
142
- ```scss
143
- <style lang="scss">
144
- /* npm 方式 */
145
- @import "uview-pro/index.scss";
146
- /* uni_modules 方式 */
147
- /* @import "@/uni_modules/uview-pro/index.scss"; */
148
- </style>
149
- ```
150
-
151
- ### 4. 配置 easycom 自动引入组件
152
-
153
- 在 `pages.json` 中配置 `easycom` 规则,实现组件自动引入:
154
-
155
- ```json
156
- {
157
- "easycom": {
158
- "autoscan": true,
159
- "custom": {
160
- // npm 方式
161
- "^u-(.*)": "uview-pro/components/u-$1/u-$1.vue"
162
- // uni_modules 方式
163
- // "^u-(.*)": "@/uni_modules/uview-pro/components/u-$1/u-$1.vue"
164
- }
165
- },
166
- "pages": []
167
- }
168
- ```
169
-
170
- **温馨提示**
171
-
172
- - 1.修改 `easycom` 规则后需重启 HX 或重新编译项目。
173
- - 2.请确保 `pages.json` 中只有一个 easycom 字段,否则请自行合并多个规则。
174
- - 3.一定要放在 `custom` 内,否则无效。
175
-
176
- ### 5. Volar 类型提示支持
177
-
178
- 如需在 `CLI` 项目中获得 `Volar` 的全局类型提示,请在 `tsconfig.json` 中添加:
179
-
180
- ```json
181
- {
182
- "compilerOptions": {
183
- // npm 方式
184
- "types": ["uview-pro/types"]
185
- // uni_modules 方式
186
- // "types": ["@/uni_modules/uview-pro/types"]
187
- }
188
- }
189
- ```
190
-
191
- > HBuilderX 项目暂不支持 `tsconfig.json` 的 `types` 配置,`CLI` 项目推荐配置以获得最佳 `TS` 体验。
192
-
193
- ### 6. 组件使用
194
-
195
- 配置完成后,无需 `import` 和 `components` 注册,可直接在 `SFC` 中使用 `uView Pro` 组件:
196
-
197
- ```vue
198
- <template>
199
- <u-button type="primary">按钮</u-button>
200
- </template>
201
- ```
202
-
203
- 请通过[快速上手](https://uview-pro.netlify.app/components/quickstart.html)了解更详细的内容
204
-
205
- ## 捐赠 uView Pro
206
-
207
- `uView Pro` 文档内容和框架源码基于 `uView UI` 二次开发,因此全部开源免费,如果您认为 `uView Pro` 帮到了您的开发工作,您可以捐赠 `uView Pro` 的研发工作,捐赠无门槛,哪怕是一杯可乐也好(相信这比打赏主播更有意义)。
208
-
209
- <table class="table">
210
- <tr>
211
- <td><img src="https://ik.imagekit.io/anyup/images/social/weixin-pay.png" width="250" height="345" ></td>
212
- <td><img src="https://ik.imagekit.io/anyup/images/social/ali-pay.png" width="250" height="345" ></td>
213
- </tr>
214
- <tr>
215
- <td align="center"><strong>微信</strong><br></td>
216
- <td align="center"><strong>支付宝</strong><br></td>
217
- </tr>
218
- </table>
219
-
220
- ## 版权信息
221
-
222
- `uView Pro` 遵循[MIT](https://en.wikipedia.org/wiki/MIT_License)开源协议,意味着您无需支付任何费用,也无需授权,即可将 `uView Pro` 应用到您的产品中。
223
-
224
- ## 鸣谢
225
-
226
- 再次感谢 `uView UI` 开发团队,以及所有为 `uView UI` 的贡献者,以及所有为 `uView Pro` 的贡献者。
227
-
228
- - [Github](https://github.com/anyup/uview-pro)
229
- - [Gitee](https://gitee.com/anyup/uview-pro)
230
- - [uView UI 1.0](https://github.com/umicro/uView)
231
- - [uView UI 2.0](https://github.com/umicro/uView2.0)
1
+ <p align="center">
2
+ <img alt="logo" src="https://ik.imagekit.io/anyup/uview-pro/common/logo.png" width="120" height="120" style="margin-bottom: 10px;">
3
+ </p>
4
+ <h3 align="center" style="margin: 30px 0 30px;font-weight: bold;font-size:40px;">uView Pro</h3>
5
+ <h3 align="center">uni-app Vue3 多平台快速开发的 UI 框架</h3>
6
+
7
+ [![star](https://gitee.com/anyup/uView-Pro/badge/star.svg)](https://gitee.com/anyup/uView-Pro)
8
+ [![fork](https://gitee.com/anyup/uView-Pro/badge/fork.svg)](https://gitee.com/anyup/uView-Pro)
9
+ [![stars](https://img.shields.io/github/stars/anyup/uView-Pro?style=flat-square&logo=GitHub)](https://github.com/anyup/uView-Pro)
10
+ [![forks](https://img.shields.io/github/forks/anyup/uView-Pro?style=flat-square&logo=GitHub)](https://github.com/anyup/uView-Pro)
11
+ [![issues](https://img.shields.io/github/issues/anyup/uView-Pro?style=flat-square&logo=GitHub)](https://github.com/anyup/uView-Pro/issues)
12
+ [![npm version](https://img.shields.io/npm/v/uview-pro)](https://www.npmjs.com/package/uview-pro)
13
+ [![Website](https://img.shields.io/badge/uView%20Pro-docs-blue?style=flat-square)](https://uview-pro.anyup.cn/)
14
+ [![node version](https://img.shields.io/badge/node-%3E%3D18-green)](https://nodejs.org/)
15
+ [![pnpm version](https://img.shields.io/badge/pnpm-%3E%3D7.30-green)](https://pnpm.io/)
16
+ [![license](https://img.shields.io/github/license/anyup/uView-Pro?style=flat-square)](https://en.wikipedia.org/wiki/MIT_License)
17
+
18
+ ## 说明
19
+
20
+ `uView UI`,是 [uni-app](https://uniapp.dcloud.io/) 生态优秀的 UI 框架,全面的组件和便捷的工具会让您信手拈来,如鱼得水。
21
+
22
+ `uView Pro`,是全面支持 Vue3.0、TypeScript 的 uni-app 生态框架,uView Pro 的基线版本是基于 uView 1.8.8 修改,使用 TypeScript 完全重构,目前已全面支持 uni-app Vue3.0。
23
+
24
+ ## [官方文档:https://uview-pro.netlify.app/](https://uview-pro.netlify.app/)
25
+
26
+ ## 特性
27
+
28
+ - 兼容安卓,iOS,微信小程序,H5,QQ 小程序,百度小程序,支付宝小程序,头条小程序
29
+ - 70+精选组件,功能丰富,多端兼容,让您快速集成,开箱即用
30
+ - 众多贴心的 JS 利器,让您飞镖在手,召之即来,百步穿杨
31
+ - 众多的常用页面和布局,让您专注逻辑,事半功倍
32
+ - 详尽的文档支持,现代化的演示效果
33
+ - 按需引入,精简打包体积
34
+
35
+ ## 手机预览
36
+
37
+ 您可以通过**微信**或**手机浏览器**扫描以下二维码,查看最佳的演示效果。
38
+
39
+ <table class="table">
40
+ <tr>
41
+ <td><img src="https://ik.imagekit.io/anyup/images/social/qr_uview_pro_wx.jpg" width="200" height="200" ></td>
42
+ <td><img src="https://ik.imagekit.io/anyup/images/social/qr_uview_pro_h5.png" width="200" height="200" ></td>
43
+ <td><img src="https://ik.imagekit.io/anyup/images/social/qr_uview_pro_android.png" width="200" height="200" ></td>
44
+ </tr>
45
+ <tr>
46
+ <td align="center"><strong>微信小程序</strong><br>(微信扫码)</td>
47
+ <td align="center"><strong>H5</strong><br>(浏览器扫码)</td>
48
+ <td align="center"><strong>Android</strong><br>(浏览器扫码)</td>
49
+ </tr>
50
+ </table>
51
+
52
+ 运行示例工程,请[下载源码](https://github.com/anyup/uview-pro)后,在项目根目录执行以下命令:
53
+
54
+ ```bash
55
+ pnpm install
56
+ pnpm dev
57
+ ```
58
+
59
+ ## 链接
60
+
61
+ - [Github](https://github.com/anyup/uview-pro)
62
+ - [Gitee](https://gitee.com/anyup/uview-pro)
63
+ - [官方文档](https://uview-pro.netlify.app/)
64
+ - [更新日志](https://github.com/anyup/uView-Pro/blob/master/src/uni_modules/uview-pro/changelog.md)
65
+
66
+ ## 交流反馈
67
+
68
+ `uView Pro` QQ 交流群: [点击进入](http://qm.qq.com/cgi-bin/qm/qr?_wv=1027&k=98nSVDldWEbDdq4lxiP4aL7uATfMSlI6&authKey=G2yQJ5MQiKzMldaxBsIfKt17NuJuUw8Fr6zdKLggc6NZXgw4BVbqkU2U3EE994yd&noverify=0&group_code=811732166)
69
+
70
+ <table class="table">
71
+ <tr>
72
+ <td><img src="https://ik.imagekit.io/anyup/images/social/weixin-chat-2.png?updatedAt=1756355426929" width="250" height="345" ></td>
73
+ <td><img src="https://ik.imagekit.io/anyup/images/social/qq-chat.png" width="250" height="345" ></td>
74
+ </tr>
75
+ <tr>
76
+ <td align="center"><strong>微信群</strong><br></td>
77
+ <td align="center"><strong>QQ群</strong><br></td>
78
+ </tr>
79
+ </table>
80
+
81
+ ## 关于 PR
82
+
83
+ 我们非常乐意接受各位的优质 PR,但在此之前我希望您了解 `uView Pro` 是一个需要兼容多个平台的(小程序、h5、iOS App、Android App)包括 nvue 页面、vue 页面。
84
+
85
+ 所以希望在您修复 bug 并提交之前尽可能的去这些平台测试一下兼容性。最好能携带测试截图以方便审核。非常感谢!
86
+
87
+ ## 安装配置
88
+
89
+ `uView Pro` 支持 `npm` 和 `uni_modules` 两种主流安装方式,配置方式高度一致。无论采用哪种方式,均可通过 `easycom` 实现组件自动引入,极大提升开发效率。以下为统一的配置说明:
90
+
91
+ ### 1. 安装 uView Pro
92
+
93
+ - npm 安装:
94
+
95
+ ```bash
96
+ npm install uview-pro
97
+ # 或
98
+ yarn add uview-pro
99
+ # 或
100
+ pnpm add uview-pro
101
+ ```
102
+
103
+ - uni_modules 安装:
104
+
105
+ 通过 HBuilderX 插件市场或手动下载,将 uView Pro 放入 `uni_modules` 目录。
106
+
107
+ [插件市场:https://ext.dcloud.net.cn/plugin?id=24633](https://ext.dcloud.net.cn/plugin?id=24633)
108
+
109
+ ### 2. 引入 uView Pro 主库
110
+
111
+ 在 `main.ts` 中引入并注册 uView Pro:
112
+
113
+ ```js
114
+ import { createSSRApp } from 'vue';
115
+ // npm 方式
116
+ import uViewPro from 'uview-pro';
117
+ // uni_modules 方式
118
+ // import uViewPro from "@/uni_modules/uview-pro";
119
+
120
+ export function createApp() {
121
+ const app = createSSRApp(App);
122
+ app.use(uViewPro);
123
+ return {
124
+ app
125
+ };
126
+ }
127
+ ```
128
+
129
+ ### 3. 引入全局样式
130
+
131
+ 在 `uni.scss` 中引入主题样式:
132
+
133
+ ```scss
134
+ /* npm 方式 */
135
+ @import 'uview-pro/theme.scss';
136
+ /* uni_modules 方式 */
137
+ /* @import "@/uni_modules/uview-pro/theme.scss"; */
138
+ ```
139
+
140
+ 在 `App.vue` 首行引入基础样式:
141
+
142
+ ```scss
143
+ <style lang="scss">
144
+ /* npm 方式 */
145
+ @import "uview-pro/index.scss";
146
+ /* uni_modules 方式 */
147
+ /* @import "@/uni_modules/uview-pro/index.scss"; */
148
+ </style>
149
+ ```
150
+
151
+ ### 4. 配置 easycom 自动引入组件
152
+
153
+ 在 `pages.json` 中配置 `easycom` 规则,实现组件自动引入:
154
+
155
+ ```json
156
+ {
157
+ "easycom": {
158
+ "autoscan": true,
159
+ "custom": {
160
+ // npm 方式
161
+ "^u-(.*)": "uview-pro/components/u-$1/u-$1.vue"
162
+ // uni_modules 方式
163
+ // "^u-(.*)": "@/uni_modules/uview-pro/components/u-$1/u-$1.vue"
164
+ }
165
+ },
166
+ "pages": []
167
+ }
168
+ ```
169
+
170
+ **温馨提示**
171
+
172
+ - 1.修改 `easycom` 规则后需重启 HX 或重新编译项目。
173
+ - 2.请确保 `pages.json` 中只有一个 easycom 字段,否则请自行合并多个规则。
174
+ - 3.一定要放在 `custom` 内,否则无效。
175
+
176
+ ### 5. Volar 类型提示支持
177
+
178
+ 如需在 `CLI` 项目中获得 `Volar` 的全局类型提示,请在 `tsconfig.json` 中添加:
179
+
180
+ ```json
181
+ {
182
+ "compilerOptions": {
183
+ // npm 方式
184
+ "types": ["uview-pro/types"]
185
+ // uni_modules 方式
186
+ // "types": ["@/uni_modules/uview-pro/types"]
187
+ }
188
+ }
189
+ ```
190
+
191
+ > HBuilderX 项目暂不支持 `tsconfig.json` 的 `types` 配置,`CLI` 项目推荐配置以获得最佳 `TS` 体验。
192
+
193
+ ### 6. 组件使用
194
+
195
+ 配置完成后,无需 `import` 和 `components` 注册,可直接在 `SFC` 中使用 `uView Pro` 组件:
196
+
197
+ ```vue
198
+ <template>
199
+ <u-button type="primary">按钮</u-button>
200
+ </template>
201
+ ```
202
+
203
+ 请通过[快速上手](https://uview-pro.netlify.app/components/quickstart.html)了解更详细的内容
204
+
205
+ ## 捐赠 uView Pro
206
+
207
+ `uView Pro` 文档内容和框架源码基于 `uView UI` 二次开发,因此全部开源免费,如果您认为 `uView Pro` 帮到了您的开发工作,您可以捐赠 `uView Pro` 的研发工作,捐赠无门槛,哪怕是一杯可乐也好(相信这比打赏主播更有意义)。
208
+
209
+ <table class="table">
210
+ <tr>
211
+ <td><img src="https://ik.imagekit.io/anyup/images/social/weixin-pay.png" width="250" height="345" ></td>
212
+ <td><img src="https://ik.imagekit.io/anyup/images/social/ali-pay.png" width="250" height="345" ></td>
213
+ </tr>
214
+ <tr>
215
+ <td align="center"><strong>微信</strong><br></td>
216
+ <td align="center"><strong>支付宝</strong><br></td>
217
+ </tr>
218
+ </table>
219
+
220
+ ## 版权信息
221
+
222
+ `uView Pro` 遵循[MIT](https://en.wikipedia.org/wiki/MIT_License)开源协议,意味着您无需支付任何费用,也无需授权,即可将 `uView Pro` 应用到您的产品中。
223
+
224
+ ## 鸣谢
225
+
226
+ 再次感谢 `uView UI` 开发团队,以及所有为 `uView UI` 的贡献者,以及所有为 `uView Pro` 的贡献者。
227
+
228
+ - [Github](https://github.com/anyup/uview-pro)
229
+ - [Gitee](https://gitee.com/anyup/uview-pro)
230
+ - [uView UI 1.0](https://github.com/umicro/uView)
231
+ - [uView UI 2.0](https://github.com/umicro/uView2.0)
package/theme.scss CHANGED
@@ -1,38 +1,38 @@
1
- // 此文件为uView的主题变量,这些变量目前只能通过uni.scss引入才有效,另外由于
2
- // uni.scss中引入的样式会同时混入到全局样式文件和单独每一个页面的样式中,造成微信程序包太大,
3
- // 故uni.scss只建议放scss变量名相关样式,其他的样式可以通过main.js或者App.vue引入
4
-
5
- $u-main-color: #303133;
6
- $u-content-color: #606266;
7
- $u-tips-color: #909399;
8
- $u-light-color: #c0c4cc;
9
- $u-border-color: #e4e7ed;
10
- $u-bg-color: #f3f4f6;
11
-
12
- $u-type-primary: #2979ff;
13
- $u-type-primary-light: #ecf5ff;
14
- $u-type-primary-disabled: #a0cfff;
15
- $u-type-primary-dark: #2b85e4;
16
-
17
- $u-type-warning: #ff9900;
18
- $u-type-warning-disabled: #fcbd71;
19
- $u-type-warning-dark: #f29100;
20
- $u-type-warning-light: #fdf6ec;
21
-
22
- $u-type-success: #19be6b;
23
- $u-type-success-disabled: #71d5a1;
24
- $u-type-success-dark: #18b566;
25
- $u-type-success-light: #dbf1e1;
26
-
27
- $u-type-error: #fa3534;
28
- $u-type-error-disabled: #fab6b6;
29
- $u-type-error-dark: #dd6161;
30
- $u-type-error-light: #fef0f0;
31
-
32
- $u-type-info: #909399;
33
- $u-type-info-disabled: #c8c9cc;
34
- $u-type-info-dark: #82848a;
35
- $u-type-info-light: #f4f4f5;
36
-
37
- $u-form-item-height: 70rpx;
38
- $u-form-item-border-color: #dcdfe6;
1
+ // 此文件为uView的主题变量,这些变量目前只能通过uni.scss引入才有效,另外由于
2
+ // uni.scss中引入的样式会同时混入到全局样式文件和单独每一个页面的样式中,造成微信程序包太大,
3
+ // 故uni.scss只建议放scss变量名相关样式,其他的样式可以通过main.js或者App.vue引入
4
+
5
+ $u-main-color: #303133;
6
+ $u-content-color: #606266;
7
+ $u-tips-color: #909399;
8
+ $u-light-color: #c0c4cc;
9
+ $u-border-color: #e4e7ed;
10
+ $u-bg-color: #f3f4f6;
11
+
12
+ $u-type-primary: #2979ff;
13
+ $u-type-primary-light: #ecf5ff;
14
+ $u-type-primary-disabled: #a0cfff;
15
+ $u-type-primary-dark: #2b85e4;
16
+
17
+ $u-type-warning: #ff9900;
18
+ $u-type-warning-disabled: #fcbd71;
19
+ $u-type-warning-dark: #f29100;
20
+ $u-type-warning-light: #fdf6ec;
21
+
22
+ $u-type-success: #19be6b;
23
+ $u-type-success-disabled: #71d5a1;
24
+ $u-type-success-dark: #18b566;
25
+ $u-type-success-light: #dbf1e1;
26
+
27
+ $u-type-error: #fa3534;
28
+ $u-type-error-disabled: #fab6b6;
29
+ $u-type-error-dark: #dd6161;
30
+ $u-type-error-light: #fef0f0;
31
+
32
+ $u-type-info: #909399;
33
+ $u-type-info-disabled: #c8c9cc;
34
+ $u-type-info-dark: #82848a;
35
+ $u-type-info-light: #f4f4f5;
36
+
37
+ $u-form-item-height: 70rpx;
38
+ $u-form-item-border-color: #dcdfe6;