uview-pro 0.3.0 → 0.3.1

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 (249) hide show
  1. package/changelog.md +584 -574
  2. package/components/common/props.ts +22 -22
  3. package/components/u-action-sheet/types.ts +37 -37
  4. package/components/u-action-sheet/u-action-sheet.vue +178 -178
  5. package/components/u-alert-tips/types.ts +41 -41
  6. package/components/u-alert-tips/u-alert-tips.vue +238 -238
  7. package/components/u-avatar/types.ts +36 -36
  8. package/components/u-avatar/u-avatar.vue +217 -217
  9. package/components/u-avatar-cropper/types.ts +23 -23
  10. package/components/u-avatar-cropper/u-avatar-cropper.vue +297 -297
  11. package/components/u-avatar-cropper/weCropper.d.ts +62 -62
  12. package/components/u-avatar-cropper/weCropper.js +1281 -1281
  13. package/components/u-avatar-cropper/weCropper.ts +1276 -1276
  14. package/components/u-back-top/types.ts +36 -36
  15. package/components/u-back-top/u-back-top.vue +140 -140
  16. package/components/u-badge/types.ts +38 -38
  17. package/components/u-badge/u-badge.vue +183 -183
  18. package/components/u-button/types.ts +66 -66
  19. package/components/u-button/u-button.vue +579 -579
  20. package/components/u-calendar/types.ts +75 -75
  21. package/components/u-calendar/u-calendar.vue +793 -793
  22. package/components/u-car-keyboard/types.ts +14 -14
  23. package/components/u-car-keyboard/u-car-keyboard.vue +262 -262
  24. package/components/u-card/types.ts +61 -61
  25. package/components/u-card/u-card.vue +209 -209
  26. package/components/u-cell-group/types.ts +19 -19
  27. package/components/u-cell-group/u-cell-group.vue +60 -60
  28. package/components/u-cell-item/types.ts +56 -56
  29. package/components/u-cell-item/u-cell-item.vue +226 -226
  30. package/components/u-checkbox/types.ts +33 -33
  31. package/components/u-checkbox/u-checkbox.vue +282 -282
  32. package/components/u-checkbox-group/types.ts +34 -34
  33. package/components/u-checkbox-group/u-checkbox-group.vue +130 -130
  34. package/components/u-circle-progress/types.ts +54 -54
  35. package/components/u-circle-progress/u-circle-progress.vue +206 -206
  36. package/components/u-city-select/types.ts +22 -22
  37. package/components/u-city-select/u-city-select.vue +276 -276
  38. package/components/u-col/types.ts +32 -32
  39. package/components/u-col/u-col.vue +142 -142
  40. package/components/u-collapse/types.ts +33 -33
  41. package/components/u-collapse/u-collapse.vue +190 -190
  42. package/components/u-collapse-item/types.ts +27 -27
  43. package/components/u-collapse-item/u-collapse-item.vue +290 -290
  44. package/components/u-column-notice/types.ts +50 -50
  45. package/components/u-column-notice/u-column-notice.vue +222 -222
  46. package/components/u-count-down/types.ts +44 -44
  47. package/components/u-count-down/u-count-down.vue +286 -286
  48. package/components/u-count-to/types.ts +34 -34
  49. package/components/u-count-to/u-count-to.vue +266 -266
  50. package/components/u-divider/types.ts +33 -33
  51. package/components/u-divider/u-divider.vue +145 -145
  52. package/components/u-dropdown/types.ts +34 -34
  53. package/components/u-dropdown/u-dropdown.vue +330 -330
  54. package/components/u-dropdown-item/types.ts +29 -29
  55. package/components/u-dropdown-item/u-dropdown-item.vue +120 -120
  56. package/components/u-empty/types.ts +38 -38
  57. package/components/u-empty/u-empty.vue +103 -103
  58. package/components/u-field/types.ts +71 -71
  59. package/components/u-field/u-field.vue +388 -388
  60. package/components/u-form/types.ts +29 -29
  61. package/components/u-form/u-form.vue +130 -130
  62. package/components/u-form-item/types.ts +72 -72
  63. package/components/u-form-item/u-form-item.vue +447 -447
  64. package/components/u-full-screen/types.ts +16 -16
  65. package/components/u-full-screen/u-full-screen.vue +103 -103
  66. package/components/u-gap/types.ts +20 -20
  67. package/components/u-gap/u-gap.vue +50 -50
  68. package/components/u-grid/types.ts +21 -21
  69. package/components/u-grid/u-grid.vue +91 -91
  70. package/components/u-grid-item/types.ts +16 -16
  71. package/components/u-grid-item/u-grid-item.vue +130 -130
  72. package/components/u-icon/types.ts +61 -61
  73. package/components/u-icon/u-icon.vue +296 -296
  74. package/components/u-image/types.ts +51 -51
  75. package/components/u-image/u-image.vue +239 -239
  76. package/components/u-index-anchor/types.ts +16 -16
  77. package/components/u-index-anchor/u-index-anchor.vue +94 -94
  78. package/components/u-index-list/types.ts +43 -43
  79. package/components/u-index-list/u-index-list.vue +352 -352
  80. package/components/u-input/types.ts +137 -137
  81. package/components/u-input/u-input.vue +288 -288
  82. package/components/u-keyboard/types.ts +40 -40
  83. package/components/u-keyboard/u-keyboard.vue +178 -178
  84. package/components/u-lazy-load/types.ts +37 -37
  85. package/components/u-lazy-load/u-lazy-load.vue +246 -246
  86. package/components/u-line/types.ts +44 -44
  87. package/components/u-line/u-line.vue +68 -68
  88. package/components/u-line-progress/types.ts +58 -58
  89. package/components/u-line-progress/u-line-progress.vue +126 -126
  90. package/components/u-link/types.ts +43 -43
  91. package/components/u-link/u-link.vue +84 -84
  92. package/components/u-loading/types.ts +35 -35
  93. package/components/u-loading/u-loading.vue +105 -105
  94. package/components/u-loading-popup/types.ts +26 -26
  95. package/components/u-loading-popup/u-loading-popup.vue +253 -253
  96. package/components/u-loadmore/types.ts +79 -79
  97. package/components/u-loadmore/u-loadmore.vue +156 -156
  98. package/components/u-mask/types.ts +40 -40
  99. package/components/u-mask/u-mask.vue +113 -113
  100. package/components/u-message-input/types.ts +74 -74
  101. package/components/u-message-input/u-message-input.vue +281 -281
  102. package/components/u-modal/types.ts +118 -118
  103. package/components/u-modal/u-modal.vue +220 -220
  104. package/components/u-navbar/types.ts +103 -103
  105. package/components/u-navbar/u-navbar.vue +251 -251
  106. package/components/u-no-network/image.ts +2 -2
  107. package/components/u-no-network/types.ts +28 -28
  108. package/components/u-no-network/u-no-network.vue +303 -303
  109. package/components/u-notice-bar/types.ts +111 -111
  110. package/components/u-notice-bar/u-notice-bar.vue +189 -189
  111. package/components/u-number-box/types.ts +42 -42
  112. package/components/u-number-box/u-number-box.vue +321 -321
  113. package/components/u-number-keyboard/types.ts +26 -26
  114. package/components/u-number-keyboard/u-number-keyboard.vue +188 -188
  115. package/components/u-picker/types.ts +123 -123
  116. package/components/u-picker/u-picker.vue +685 -685
  117. package/components/u-popup/types.ts +59 -59
  118. package/components/u-popup/u-popup.vue +385 -385
  119. package/components/u-radio/types.ts +27 -27
  120. package/components/u-radio/u-radio.vue +279 -279
  121. package/components/u-radio-group/types.ts +31 -31
  122. package/components/u-radio-group/u-radio-group.vue +96 -96
  123. package/components/u-rate/types.ts +42 -42
  124. package/components/u-rate/u-rate.vue +249 -249
  125. package/components/u-read-more/types.ts +37 -37
  126. package/components/u-read-more/u-read-more.vue +172 -172
  127. package/components/u-root-portal/u-root-portal.vue +56 -56
  128. package/components/u-row/types.ts +22 -22
  129. package/components/u-row/u-row.vue +105 -105
  130. package/components/u-row-notice/types.ts +41 -41
  131. package/components/u-row-notice/u-row-notice.vue +256 -256
  132. package/components/u-safe-bottom/u-safe-bottom.vue +57 -57
  133. package/components/u-search/types.ts +55 -55
  134. package/components/u-search/u-search.vue +279 -279
  135. package/components/u-section/types.ts +34 -34
  136. package/components/u-section/u-section.vue +150 -150
  137. package/components/u-select/types.ts +45 -45
  138. package/components/u-select/u-select.vue +388 -388
  139. package/components/u-skeleton/types.ts +22 -22
  140. package/components/u-skeleton/u-skeleton.vue +231 -231
  141. package/components/u-slider/types.ts +34 -34
  142. package/components/u-slider/u-slider.vue +255 -255
  143. package/components/u-status-bar/u-status-bar.vue +74 -74
  144. package/components/u-steps/types.ts +30 -30
  145. package/components/u-steps/u-steps.vue +181 -181
  146. package/components/u-sticky/types.ts +24 -24
  147. package/components/u-sticky/u-sticky.vue +178 -178
  148. package/components/u-subsection/types.ts +38 -38
  149. package/components/u-subsection/u-subsection.vue +339 -339
  150. package/components/u-swipe-action/types.ts +52 -52
  151. package/components/u-swipe-action/u-swipe-action.vue +276 -276
  152. package/components/u-swiper/types.ts +49 -49
  153. package/components/u-swiper/u-swiper.vue +308 -308
  154. package/components/u-switch/types.ts +30 -30
  155. package/components/u-switch/u-switch.vue +150 -150
  156. package/components/u-tabbar/types.ts +38 -38
  157. package/components/u-tabbar/u-tabbar.vue +315 -315
  158. package/components/u-table/types.ts +27 -27
  159. package/components/u-table/u-table.vue +67 -67
  160. package/components/u-tabs/types.ts +53 -53
  161. package/components/u-tabs/u-tabs.vue +302 -302
  162. package/components/u-tabs-swiper/types.ts +55 -55
  163. package/components/u-tabs-swiper/u-tabs-swiper.vue +409 -409
  164. package/components/u-tag/types.ts +39 -39
  165. package/components/u-tag/u-tag.vue +268 -268
  166. package/components/u-td/types.ts +14 -14
  167. package/components/u-td/u-td.vue +98 -98
  168. package/components/u-text/types.ts +72 -72
  169. package/components/u-text/u-text.vue +343 -343
  170. package/components/u-th/types.ts +14 -14
  171. package/components/u-th/u-th.vue +92 -92
  172. package/components/u-time-line/u-time-line.vue +53 -53
  173. package/components/u-time-line-item/types.ts +16 -16
  174. package/components/u-time-line-item/u-time-line-item.vue +90 -90
  175. package/components/u-toast/types.ts +38 -38
  176. package/components/u-toast/u-toast.vue +240 -240
  177. package/components/u-top-tips/types.ts +16 -16
  178. package/components/u-top-tips/u-top-tips.vue +130 -130
  179. package/components/u-tr/types.ts +11 -11
  180. package/components/u-tr/u-tr.vue +39 -39
  181. package/components/u-upload/types.ts +82 -82
  182. package/components/u-upload/u-upload.vue +568 -568
  183. package/components/u-verification-code/types.ts +24 -24
  184. package/components/u-verification-code/u-verification-code.vue +176 -176
  185. package/components/u-waterfall/types.ts +18 -18
  186. package/components/u-waterfall/u-waterfall.vue +187 -187
  187. package/iconfont.css +913 -913
  188. package/index.scss +25 -25
  189. package/index.ts +38 -38
  190. package/libs/config/config.ts +26 -26
  191. package/libs/config/zIndex.ts +37 -37
  192. package/libs/css/color.scss +155 -155
  193. package/libs/css/common.scss +178 -178
  194. package/libs/css/style.components.scss +16 -16
  195. package/libs/css/style.h5.scss +8 -8
  196. package/libs/css/style.mp.scss +72 -72
  197. package/libs/css/style.nvue.scss +15 -15
  198. package/libs/css/style.vue.scss +188 -188
  199. package/libs/function/$parent.ts +24 -24
  200. package/libs/function/addUnit.ts +13 -13
  201. package/libs/function/color.ts +37 -37
  202. package/libs/function/colorGradient.ts +139 -139
  203. package/libs/function/debounce.ts +28 -28
  204. package/libs/function/deepClone.ts +39 -39
  205. package/libs/function/deepMerge.ts +35 -35
  206. package/libs/function/getParent.ts +63 -63
  207. package/libs/function/getRect.ts +26 -26
  208. package/libs/function/guid.ts +42 -42
  209. package/libs/function/md5.ts +403 -403
  210. package/libs/function/parent.ts +21 -21
  211. package/libs/function/queryParams.ts +64 -64
  212. package/libs/function/random.ts +16 -16
  213. package/libs/function/randomArray.ts +11 -11
  214. package/libs/function/route.ts +118 -118
  215. package/libs/function/styleUtils.ts +83 -83
  216. package/libs/function/sys.ts +15 -15
  217. package/libs/function/test.ts +289 -289
  218. package/libs/function/throttle.ts +31 -31
  219. package/libs/function/timeFormat.ts +55 -55
  220. package/libs/function/timeFrom.ts +48 -48
  221. package/libs/function/toast.ts +14 -14
  222. package/libs/function/trim.ts +21 -21
  223. package/libs/function/type2icon.ts +39 -39
  224. package/libs/hooks/index.ts +4 -4
  225. package/libs/hooks/useCompRelation.ts +364 -364
  226. package/libs/hooks/useComponent.ts +759 -759
  227. package/libs/hooks/useEmitter.ts +79 -79
  228. package/libs/hooks/useParent.ts +33 -33
  229. package/libs/hooks/useRect.ts +33 -33
  230. package/libs/index.ts +337 -337
  231. package/libs/request/auto-http.ts +76 -76
  232. package/libs/request/index.ts +242 -242
  233. package/libs/store/index.ts +88 -88
  234. package/libs/util/async-validator.d.ts +75 -75
  235. package/libs/util/async-validator.js +1 -1
  236. package/libs/util/calendar.d.ts +57 -57
  237. package/libs/util/emitter.ts +112 -112
  238. package/libs/util/eventBus.ts +86 -86
  239. package/libs/util/logger.ts +364 -364
  240. package/libs/util/mitt.ts +118 -118
  241. package/libs/util/parent.ts +20 -20
  242. package/package.json +4 -4
  243. package/readme.md +241 -241
  244. package/theme.scss +38 -38
  245. package/types/components.d.ts +97 -97
  246. package/types/global.d.ts +331 -331
  247. package/types/ignore-errors.d.ts +30 -30
  248. package/types/index.d.ts +19 -19
  249. package/types/uni-app.d.ts +63 -63
@@ -1,51 +1,51 @@
1
- import { type ComponentPublicInstance, type ExtractPropTypes, type PropType } from 'vue';
2
- import type { ImgMode, Shape } from '../../types/global';
3
-
4
- // 定义 ImageProps 的类型
5
- export const ImageProps = {
6
- /** 图片地址 */
7
- src: { type: String, default: '' },
8
- /** 裁剪模式 */
9
- mode: { type: String as PropType<ImgMode>, default: 'aspectFill' },
10
- /** 宽度,单位任意,如果为数值,则为rpx单位(默认100%) */
11
- width: { type: [String, Number], default: '100%' },
12
- /** 高度,单位任意,如果为数值,则为rpx单位(默认 auto) */
13
- height: { type: [String, Number], default: 'auto' },
14
- /** 图片形状,circle-圆形,square-方形(默认square) */
15
- shape: { type: String as PropType<Shape>, default: 'square' },
16
- /** 圆角值,单位任意,如果为数值,则为rpx单位(默认 0) */
17
- borderRadius: { type: [String, Number], default: 0 },
18
- /** 是否懒加载,仅微信小程序、App、百度小程序、字节跳动小程序有效(默认 true) */
19
- lazyLoad: { type: Boolean, default: true },
20
- /** 是否开启长按图片显示识别小程序码菜单,仅微信小程序有效(默认 true) */
21
- showMenuByLongpress: { type: Boolean, default: true },
22
- /** 加载中的图标,或者小图片(默认 photo) */
23
- loadingIcon: { type: String, default: 'photo' },
24
- /** 加载失败的图标,或者小图片(默认 error-circle) */
25
- errorIcon: { type: String, default: 'error-circle' },
26
- /** 是否显示加载中的图标或者自定义的slot(默认 true) */
27
- showLoading: { type: Boolean, default: true },
28
- /** 是否显示加载错误的图标或者自定义的slot(默认 true) */
29
- showError: { type: Boolean, default: true },
30
- /** 是否需要淡入效果(默认 true) */
31
- fade: { type: Boolean, default: true },
32
- /** 只支持网络资源,只对微信小程序有效(默认 false) */
33
- webp: { type: Boolean, default: false },
34
- /** 搭配fade参数的过渡时间,单位ms(默认 500) */
35
- duration: { type: [String, Number], default: 500 },
36
- /** 背景颜色,用于深色页面加载图片时,为了和背景色融合(默认 #f3f4f6) */
37
- bgColor: { type: String, default: '#f3f4f6' },
38
- /** 使用插槽名称对象,用于自定义插槽,默认 undefined,当动态切换slot隐藏时,需要使用useSlots使用,兼容头条小程序 */
39
- useSlots: { type: Object as PropType<Record<string, boolean>>, default: undefined }
40
- };
41
-
42
- // 将 ImageProps 转换为类型
43
- export type ImageProps = ExtractPropTypes<typeof ImageProps>;
44
-
45
- // 暴露的组件实例方法
46
- export type ImageExpose = {
47
- changeStatus: (status: 'loading' | 'error' | 'normal') => void;
48
- };
49
-
50
- // 组件实例类型
51
- export type ImageInstance = ComponentPublicInstance<ImageProps, ImageExpose>;
1
+ import { type ComponentPublicInstance, type ExtractPropTypes, type PropType } from 'vue';
2
+ import type { ImgMode, Shape } from '../../types/global';
3
+
4
+ // 定义 ImageProps 的类型
5
+ export const ImageProps = {
6
+ /** 图片地址 */
7
+ src: { type: String, default: '' },
8
+ /** 裁剪模式 */
9
+ mode: { type: String as PropType<ImgMode>, default: 'aspectFill' },
10
+ /** 宽度,单位任意,如果为数值,则为rpx单位(默认100%) */
11
+ width: { type: [String, Number], default: '100%' },
12
+ /** 高度,单位任意,如果为数值,则为rpx单位(默认 auto) */
13
+ height: { type: [String, Number], default: 'auto' },
14
+ /** 图片形状,circle-圆形,square-方形(默认square) */
15
+ shape: { type: String as PropType<Shape>, default: 'square' },
16
+ /** 圆角值,单位任意,如果为数值,则为rpx单位(默认 0) */
17
+ borderRadius: { type: [String, Number], default: 0 },
18
+ /** 是否懒加载,仅微信小程序、App、百度小程序、字节跳动小程序有效(默认 true) */
19
+ lazyLoad: { type: Boolean, default: true },
20
+ /** 是否开启长按图片显示识别小程序码菜单,仅微信小程序有效(默认 true) */
21
+ showMenuByLongpress: { type: Boolean, default: true },
22
+ /** 加载中的图标,或者小图片(默认 photo) */
23
+ loadingIcon: { type: String, default: 'photo' },
24
+ /** 加载失败的图标,或者小图片(默认 error-circle) */
25
+ errorIcon: { type: String, default: 'error-circle' },
26
+ /** 是否显示加载中的图标或者自定义的slot(默认 true) */
27
+ showLoading: { type: Boolean, default: true },
28
+ /** 是否显示加载错误的图标或者自定义的slot(默认 true) */
29
+ showError: { type: Boolean, default: true },
30
+ /** 是否需要淡入效果(默认 true) */
31
+ fade: { type: Boolean, default: true },
32
+ /** 只支持网络资源,只对微信小程序有效(默认 false) */
33
+ webp: { type: Boolean, default: false },
34
+ /** 搭配fade参数的过渡时间,单位ms(默认 500) */
35
+ duration: { type: [String, Number], default: 500 },
36
+ /** 背景颜色,用于深色页面加载图片时,为了和背景色融合(默认 #f3f4f6) */
37
+ bgColor: { type: String, default: '#f3f4f6' },
38
+ /** 使用插槽名称对象,用于自定义插槽,默认 undefined,当动态切换slot隐藏时,需要使用useSlots使用,兼容头条小程序 */
39
+ useSlots: { type: Object as PropType<Record<string, boolean>>, default: undefined }
40
+ };
41
+
42
+ // 将 ImageProps 转换为类型
43
+ export type ImageProps = ExtractPropTypes<typeof ImageProps>;
44
+
45
+ // 暴露的组件实例方法
46
+ export type ImageExpose = {
47
+ changeStatus: (status: 'loading' | 'error' | 'normal') => void;
48
+ };
49
+
50
+ // 组件实例类型
51
+ export type ImageInstance = ComponentPublicInstance<ImageProps, ImageExpose>;
@@ -1,239 +1,239 @@
1
- <template>
2
- <view class="u-image" @tap="onClick" :style="[wrapStyle, backgroundStyle]">
3
- <image
4
- v-if="!isError"
5
- :src="src"
6
- :mode="mode"
7
- @error="onErrorHandler"
8
- @load="onLoadHandler"
9
- :lazy-load="lazyLoad"
10
- class="u-image__image"
11
- :show-menu-by-longpress="showMenuByLongpress"
12
- :style="{ borderRadius: shape === 'circle' ? '50%' : $u.addUnit(borderRadius) }"
13
- ></image>
14
- <view
15
- v-if="showLoading && loading"
16
- class="u-image__loading"
17
- :style="{ borderRadius: shape === 'circle' ? '50%' : $u.addUnit(borderRadius), backgroundColor: bgColor }"
18
- >
19
- <slot v-if="hasSlot('loading')" name="loading" />
20
- <u-icon v-else :name="loadingIcon" :width="width" :height="height"></u-icon>
21
- </view>
22
- <view
23
- v-if="showError && isError && !loading"
24
- class="u-image__error"
25
- :style="{ borderRadius: shape === 'circle' ? '50%' : $u.addUnit(borderRadius) }"
26
- >
27
- <slot v-if="hasSlot('error')" name="error" />
28
- <u-icon v-else :name="errorIcon" :width="width" :height="height"></u-icon>
29
- </view>
30
- </view>
31
- </template>
32
-
33
- <script lang="ts">
34
- export default {
35
- name: 'u-image',
36
- options: {
37
- addGlobalClass: true,
38
- // #ifndef MP-TOUTIAO
39
- virtualHost: true,
40
- // #endif
41
- styleIsolation: 'shared'
42
- }
43
- };
44
- </script>
45
-
46
- <script setup lang="ts">
47
- import { ref, computed, watch, useSlots } from 'vue';
48
- import { type ImageExpose, ImageProps } from './types';
49
- import { $u } from '../..';
50
-
51
- /**
52
- * Image 图片
53
- * @description 此组件为uni-app的image组件的加强版,在继承了原有功能外,还支持淡入动画、加载中、加载失败提示、圆角值和形状等。
54
- * @tutorial https://uviewpro.cn/zh/components/image.html
55
- * @property {String} src 图片地址
56
- * @property {String} mode 裁剪模式,见官网说明
57
- * @property {String | Number} width 宽度,单位任意,如果为数值,则为rpx单位(默认100%)
58
- * @property {String | Number} height 高度,单位任意,如果为数值,则为rpx单位(默认 auto)
59
- * @property {String} shape 图片形状,circle-圆形,square-方形(默认square)
60
- * @property {String | Number} border-radius 圆角值,单位任意,如果为数值,则为rpx单位(默认 0)
61
- * @property {Boolean} lazy-load 是否懒加载,仅微信小程序、App、百度小程序、字节跳动小程序有效(默认 true)
62
- * @property {Boolean} show-menu-by-longpress 是否开启长按图片显示识别小程序码菜单,仅微信小程序有效(默认 false)
63
- * @property {String} loading-icon 加载中的图标,或者小图片(默认 photo)
64
- * @property {String} error-icon 加载失败的图标,或者小图片(默认 error-circle)
65
- * @property {Boolean} show-loading 是否显示加载中的图标或者自定义的slot(默认 true)
66
- * @property {Boolean} show-error 是否显示加载错误的图标或者自定义的slot(默认 true)
67
- * @property {Boolean} fade 是否需要淡入效果(默认 true)
68
- * @property {Boolean} webp 只支持网络资源,只对微信小程序有效(默认 false)
69
- * @property {String | Number} duration 搭配fade参数的过渡时间,单位ms(默认 500)
70
- * @property {String} bg-color 背景颜色,用于深色页面加载图片时,为了和背景色融合(默认 #f3f4f6)
71
- * @event {Function} click 点击图片时触发
72
- * @event {Function} error 图片加载失败时触发
73
- * @event {Function} load 图片加载成功时触发
74
- * @example <u-image width="100%" height="300rpx" :src="src"></u-image>
75
- */
76
-
77
- const emit = defineEmits<{
78
- (e: 'click'): void;
79
- (e: 'error', err: any): void;
80
- (e: 'load'): void;
81
- }>();
82
-
83
- const props = defineProps(ImageProps);
84
-
85
- // 图片是否加载错误,如果是,则显示错误占位图
86
- const isError = ref(false);
87
- // 初始化组件时,默认为加载中状态
88
- const loading = ref(true);
89
- // 不透明度,为了实现淡入淡出的效果
90
- const opacity = ref(1);
91
- // 过渡时间,因为props的值无法修改,故需要一个中间值
92
- const durationTime = ref(props.duration);
93
- // 图片加载完成时,去掉背景颜色,因为如果是png图片,就会显示灰色的背景
94
- const backgroundStyle = ref<Record<string, any>>({});
95
-
96
- // 监听src变化,处理加载状态
97
- watch(
98
- () => props.src,
99
- n => {
100
- if (!n) {
101
- // 如果传入null或者'',或者false,或者undefined,标记为错误状态
102
- isError.value = true;
103
- loading.value = false;
104
- } else {
105
- isError.value = false;
106
- loading.value = true;
107
- }
108
- },
109
- { immediate: true }
110
- );
111
-
112
- /**
113
- * 计算图片外层包裹样式
114
- * @returns {Record<string, any>}
115
- */
116
- const wrapStyle = computed(() => {
117
- let style: Record<string, any> = {};
118
- // 通过调用addUnit()方法,如果有单位,如百分比,px单位等,直接返回,如果是纯粹的数值,则加上rpx单位
119
- style.width = $u.addUnit(props.width);
120
- style.height = $u.addUnit(props.height);
121
- // 如果是配置了圆形,设置50%的圆角,否则按照默认的配置值
122
- style.borderRadius = props.shape === 'circle' ? '50%' : $u.addUnit(props.borderRadius);
123
- // 如果设置圆角,必须要有hidden,否则可能圆角无效
124
- style.overflow = Number(props.borderRadius) > 0 ? 'hidden' : 'visible';
125
- if (props.fade) {
126
- style.opacity = opacity.value;
127
- style.transition = `opacity ${Number(durationTime.value) / 1000}s ease-in-out`;
128
- }
129
- return style;
130
- });
131
-
132
- /**
133
- * 点击图片
134
- * @emits click
135
- */
136
- function onClick() {
137
- emit('click');
138
- }
139
-
140
- /**
141
- * 图片加载失败
142
- * @param err 失败事件对象
143
- * @emits error
144
- */
145
- function onErrorHandler(err: any) {
146
- loading.value = false;
147
- isError.value = true;
148
- emit('error', err);
149
- }
150
-
151
- /**
152
- * 图片加载完成,标记loading结束
153
- * @emits load
154
- */
155
- function onLoadHandler() {
156
- loading.value = false;
157
- isError.value = false;
158
- emit('load');
159
- // 如果不需要动画效果,就不执行下方代码,同时移除加载时的背景颜色
160
- // 否则无需fade效果时,png图片依然能看到下方的背景色
161
- if (!props.fade) return removeBgColor();
162
- // 原来opacity为1(不透明,是为了显示占位图),改成0(透明,意味着该元素显示的是背景颜色,默认的灰色),再改成1,是为了获得过渡效果
163
- opacity.value = 0;
164
- // 这里设置为0,是为了图片展示到背景全透明这个过程时间为0,延时之后延时之后重新设置为duration,是为了获得背景透明(灰色)
165
- // 到图片展示的过程中的淡入效果
166
- durationTime.value = 0;
167
- // 延时50ms,否则在浏览器H5,过渡效果无效
168
- setTimeout(() => {
169
- durationTime.value = props.duration;
170
- opacity.value = 1;
171
- setTimeout(() => {
172
- removeBgColor();
173
- }, Number(durationTime.value));
174
- }, 50);
175
- }
176
-
177
- /**
178
- * 移除图片的背景色
179
- * 淡入动画过渡完成后,将背景设置为透明色,否则png图片会看到灰色的背景
180
- */
181
- function removeBgColor() {
182
- backgroundStyle.value = {
183
- backgroundColor: 'transparent'
184
- };
185
- }
186
-
187
- function changeStatus(status: 'loading' | 'error' | 'normal') {
188
- if (status === 'loading') {
189
- loading.value = true;
190
- isError.value = false;
191
- } else if (status === 'error') {
192
- loading.value = false;
193
- isError.value = true;
194
- } else {
195
- loading.value = false;
196
- isError.value = false;
197
- }
198
- }
199
-
200
- // 暴露给模板
201
- const $slots = useSlots();
202
-
203
- function hasSlot(name: string) {
204
- return props.useSlots ? !!$slots[name] && props.useSlots[name] : !!$slots[name];
205
- }
206
-
207
- defineExpose<ImageExpose>({
208
- changeStatus
209
- });
210
- </script>
211
-
212
- <style scoped lang="scss">
213
- @import '../../libs/css/style.components.scss';
214
-
215
- .u-image {
216
- position: relative;
217
- transition: opacity 0.5s ease-in-out;
218
-
219
- &__image {
220
- width: 100%;
221
- height: 100%;
222
- }
223
-
224
- &__loading,
225
- &__error {
226
- position: absolute;
227
- top: 0;
228
- left: 0;
229
- width: 100%;
230
- height: 100%;
231
- @include vue-flex;
232
- align-items: center;
233
- justify-content: center;
234
- background-color: $u-bg-color;
235
- color: $u-tips-color;
236
- font-size: 46rpx;
237
- }
238
- }
239
- </style>
1
+ <template>
2
+ <view class="u-image" @tap="onClick" :style="[wrapStyle, backgroundStyle]">
3
+ <image
4
+ v-if="!isError"
5
+ :src="src"
6
+ :mode="mode"
7
+ @error="onErrorHandler"
8
+ @load="onLoadHandler"
9
+ :lazy-load="lazyLoad"
10
+ class="u-image__image"
11
+ :show-menu-by-longpress="showMenuByLongpress"
12
+ :style="{ borderRadius: shape === 'circle' ? '50%' : $u.addUnit(borderRadius) }"
13
+ ></image>
14
+ <view
15
+ v-if="showLoading && loading"
16
+ class="u-image__loading"
17
+ :style="{ borderRadius: shape === 'circle' ? '50%' : $u.addUnit(borderRadius), backgroundColor: bgColor }"
18
+ >
19
+ <slot v-if="hasSlot('loading')" name="loading" />
20
+ <u-icon v-else :name="loadingIcon" :width="width" :height="height"></u-icon>
21
+ </view>
22
+ <view
23
+ v-if="showError && isError && !loading"
24
+ class="u-image__error"
25
+ :style="{ borderRadius: shape === 'circle' ? '50%' : $u.addUnit(borderRadius) }"
26
+ >
27
+ <slot v-if="hasSlot('error')" name="error" />
28
+ <u-icon v-else :name="errorIcon" :width="width" :height="height"></u-icon>
29
+ </view>
30
+ </view>
31
+ </template>
32
+
33
+ <script lang="ts">
34
+ export default {
35
+ name: 'u-image',
36
+ options: {
37
+ addGlobalClass: true,
38
+ // #ifndef MP-TOUTIAO
39
+ virtualHost: true,
40
+ // #endif
41
+ styleIsolation: 'shared'
42
+ }
43
+ };
44
+ </script>
45
+
46
+ <script setup lang="ts">
47
+ import { ref, computed, watch, useSlots } from 'vue';
48
+ import { type ImageExpose, ImageProps } from './types';
49
+ import { $u } from '../..';
50
+
51
+ /**
52
+ * Image 图片
53
+ * @description 此组件为uni-app的image组件的加强版,在继承了原有功能外,还支持淡入动画、加载中、加载失败提示、圆角值和形状等。
54
+ * @tutorial https://uviewpro.cn/zh/components/image.html
55
+ * @property {String} src 图片地址
56
+ * @property {String} mode 裁剪模式,见官网说明
57
+ * @property {String | Number} width 宽度,单位任意,如果为数值,则为rpx单位(默认100%)
58
+ * @property {String | Number} height 高度,单位任意,如果为数值,则为rpx单位(默认 auto)
59
+ * @property {String} shape 图片形状,circle-圆形,square-方形(默认square)
60
+ * @property {String | Number} border-radius 圆角值,单位任意,如果为数值,则为rpx单位(默认 0)
61
+ * @property {Boolean} lazy-load 是否懒加载,仅微信小程序、App、百度小程序、字节跳动小程序有效(默认 true)
62
+ * @property {Boolean} show-menu-by-longpress 是否开启长按图片显示识别小程序码菜单,仅微信小程序有效(默认 false)
63
+ * @property {String} loading-icon 加载中的图标,或者小图片(默认 photo)
64
+ * @property {String} error-icon 加载失败的图标,或者小图片(默认 error-circle)
65
+ * @property {Boolean} show-loading 是否显示加载中的图标或者自定义的slot(默认 true)
66
+ * @property {Boolean} show-error 是否显示加载错误的图标或者自定义的slot(默认 true)
67
+ * @property {Boolean} fade 是否需要淡入效果(默认 true)
68
+ * @property {Boolean} webp 只支持网络资源,只对微信小程序有效(默认 false)
69
+ * @property {String | Number} duration 搭配fade参数的过渡时间,单位ms(默认 500)
70
+ * @property {String} bg-color 背景颜色,用于深色页面加载图片时,为了和背景色融合(默认 #f3f4f6)
71
+ * @event {Function} click 点击图片时触发
72
+ * @event {Function} error 图片加载失败时触发
73
+ * @event {Function} load 图片加载成功时触发
74
+ * @example <u-image width="100%" height="300rpx" :src="src"></u-image>
75
+ */
76
+
77
+ const emit = defineEmits<{
78
+ (e: 'click'): void;
79
+ (e: 'error', err: any): void;
80
+ (e: 'load'): void;
81
+ }>();
82
+
83
+ const props = defineProps(ImageProps);
84
+
85
+ // 图片是否加载错误,如果是,则显示错误占位图
86
+ const isError = ref(false);
87
+ // 初始化组件时,默认为加载中状态
88
+ const loading = ref(true);
89
+ // 不透明度,为了实现淡入淡出的效果
90
+ const opacity = ref(1);
91
+ // 过渡时间,因为props的值无法修改,故需要一个中间值
92
+ const durationTime = ref(props.duration);
93
+ // 图片加载完成时,去掉背景颜色,因为如果是png图片,就会显示灰色的背景
94
+ const backgroundStyle = ref<Record<string, any>>({});
95
+
96
+ // 监听src变化,处理加载状态
97
+ watch(
98
+ () => props.src,
99
+ n => {
100
+ if (!n) {
101
+ // 如果传入null或者'',或者false,或者undefined,标记为错误状态
102
+ isError.value = true;
103
+ loading.value = false;
104
+ } else {
105
+ isError.value = false;
106
+ loading.value = true;
107
+ }
108
+ },
109
+ { immediate: true }
110
+ );
111
+
112
+ /**
113
+ * 计算图片外层包裹样式
114
+ * @returns {Record<string, any>}
115
+ */
116
+ const wrapStyle = computed(() => {
117
+ let style: Record<string, any> = {};
118
+ // 通过调用addUnit()方法,如果有单位,如百分比,px单位等,直接返回,如果是纯粹的数值,则加上rpx单位
119
+ style.width = $u.addUnit(props.width);
120
+ style.height = $u.addUnit(props.height);
121
+ // 如果是配置了圆形,设置50%的圆角,否则按照默认的配置值
122
+ style.borderRadius = props.shape === 'circle' ? '50%' : $u.addUnit(props.borderRadius);
123
+ // 如果设置圆角,必须要有hidden,否则可能圆角无效
124
+ style.overflow = Number(props.borderRadius) > 0 ? 'hidden' : 'visible';
125
+ if (props.fade) {
126
+ style.opacity = opacity.value;
127
+ style.transition = `opacity ${Number(durationTime.value) / 1000}s ease-in-out`;
128
+ }
129
+ return style;
130
+ });
131
+
132
+ /**
133
+ * 点击图片
134
+ * @emits click
135
+ */
136
+ function onClick() {
137
+ emit('click');
138
+ }
139
+
140
+ /**
141
+ * 图片加载失败
142
+ * @param err 失败事件对象
143
+ * @emits error
144
+ */
145
+ function onErrorHandler(err: any) {
146
+ loading.value = false;
147
+ isError.value = true;
148
+ emit('error', err);
149
+ }
150
+
151
+ /**
152
+ * 图片加载完成,标记loading结束
153
+ * @emits load
154
+ */
155
+ function onLoadHandler() {
156
+ loading.value = false;
157
+ isError.value = false;
158
+ emit('load');
159
+ // 如果不需要动画效果,就不执行下方代码,同时移除加载时的背景颜色
160
+ // 否则无需fade效果时,png图片依然能看到下方的背景色
161
+ if (!props.fade) return removeBgColor();
162
+ // 原来opacity为1(不透明,是为了显示占位图),改成0(透明,意味着该元素显示的是背景颜色,默认的灰色),再改成1,是为了获得过渡效果
163
+ opacity.value = 0;
164
+ // 这里设置为0,是为了图片展示到背景全透明这个过程时间为0,延时之后延时之后重新设置为duration,是为了获得背景透明(灰色)
165
+ // 到图片展示的过程中的淡入效果
166
+ durationTime.value = 0;
167
+ // 延时50ms,否则在浏览器H5,过渡效果无效
168
+ setTimeout(() => {
169
+ durationTime.value = props.duration;
170
+ opacity.value = 1;
171
+ setTimeout(() => {
172
+ removeBgColor();
173
+ }, Number(durationTime.value));
174
+ }, 50);
175
+ }
176
+
177
+ /**
178
+ * 移除图片的背景色
179
+ * 淡入动画过渡完成后,将背景设置为透明色,否则png图片会看到灰色的背景
180
+ */
181
+ function removeBgColor() {
182
+ backgroundStyle.value = {
183
+ backgroundColor: 'transparent'
184
+ };
185
+ }
186
+
187
+ function changeStatus(status: 'loading' | 'error' | 'normal') {
188
+ if (status === 'loading') {
189
+ loading.value = true;
190
+ isError.value = false;
191
+ } else if (status === 'error') {
192
+ loading.value = false;
193
+ isError.value = true;
194
+ } else {
195
+ loading.value = false;
196
+ isError.value = false;
197
+ }
198
+ }
199
+
200
+ // 暴露给模板
201
+ const $slots = useSlots();
202
+
203
+ function hasSlot(name: string) {
204
+ return props.useSlots ? !!$slots[name] && props.useSlots[name] : !!$slots[name];
205
+ }
206
+
207
+ defineExpose<ImageExpose>({
208
+ changeStatus
209
+ });
210
+ </script>
211
+
212
+ <style scoped lang="scss">
213
+ @import '../../libs/css/style.components.scss';
214
+
215
+ .u-image {
216
+ position: relative;
217
+ transition: opacity 0.5s ease-in-out;
218
+
219
+ &__image {
220
+ width: 100%;
221
+ height: 100%;
222
+ }
223
+
224
+ &__loading,
225
+ &__error {
226
+ position: absolute;
227
+ top: 0;
228
+ left: 0;
229
+ width: 100%;
230
+ height: 100%;
231
+ @include vue-flex;
232
+ align-items: center;
233
+ justify-content: center;
234
+ background-color: $u-bg-color;
235
+ color: $u-tips-color;
236
+ font-size: 46rpx;
237
+ }
238
+ }
239
+ </style>
@@ -1,16 +1,16 @@
1
- import type { ExtractPropTypes, PropType } from 'vue';
2
- import { baseProps } from '../common/props';
3
-
4
- /**
5
- * u-index-anchor 组件 Props 类型定义
6
- * @description 索引锚点属性
7
- */
8
- export const IndexAnchorProps = {
9
- ...baseProps,
10
- /** 是否使用自定义内容的插槽 */
11
- useSlot: { type: Boolean, default: false },
12
- /** 索引字符,如果定义了use-slot,此参数自动失效 */
13
- index: { type: String, default: '' }
14
- };
15
-
16
- export type IndexAnchorProps = ExtractPropTypes<typeof IndexAnchorProps>;
1
+ import type { ExtractPropTypes, PropType } from 'vue';
2
+ import { baseProps } from '../common/props';
3
+
4
+ /**
5
+ * u-index-anchor 组件 Props 类型定义
6
+ * @description 索引锚点属性
7
+ */
8
+ export const IndexAnchorProps = {
9
+ ...baseProps,
10
+ /** 是否使用自定义内容的插槽 */
11
+ useSlot: { type: Boolean, default: false },
12
+ /** 索引字符,如果定义了use-slot,此参数自动失效 */
13
+ index: { type: String, default: '' }
14
+ };
15
+
16
+ export type IndexAnchorProps = ExtractPropTypes<typeof IndexAnchorProps>;