u-image.js 4.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138
  1. "use strict";
  2. const uni_modules_uviewPlus_components_uImage_props = require("./props.js");
  3. const uni_modules_uviewPlus_libs_mixin_mpMixin = require("../../libs/mixin/mpMixin.js");
  4. const uni_modules_uviewPlus_libs_mixin_mixin = require("../../libs/mixin/mixin.js");
  5. const uni_modules_uviewPlus_libs_function_index = require("../../libs/function/index.js");
  6. const common_vendor = require("../../../../common/vendor.js");
  7. const _sfc_main = {
  8. name: "u-image",
  9. mixins: [uni_modules_uviewPlus_libs_mixin_mpMixin.mpMixin, uni_modules_uviewPlus_libs_mixin_mixin.mixin, uni_modules_uviewPlus_components_uImage_props.props],
  10. data() {
  11. return {
  12. // 图片是否加载错误,如果是,则显示错误占位图
  13. isError: false,
  14. // 初始化组件时,默认为加载中状态
  15. loading: true,
  16. // 不透明度,为了实现淡入淡出的效果
  17. opacity: 1,
  18. // 过渡时间,因为props的值无法修改,故需要一个中间值
  19. durationTime: this.duration,
  20. // 图片加载完成时,去掉背景颜色,因为如果是png图片,就会显示灰色的背景
  21. backgroundStyle: {},
  22. // 用于fade模式的控制组件显示与否
  23. show: false
  24. };
  25. },
  26. watch: {
  27. src: {
  28. immediate: true,
  29. handler(n) {
  30. if (!n) {
  31. this.isError = true;
  32. } else {
  33. this.isError = false;
  34. this.loading = true;
  35. }
  36. }
  37. }
  38. },
  39. computed: {
  40. wrapStyle() {
  41. let style = {};
  42. style.width = uni_modules_uviewPlus_libs_function_index.addUnit(this.width);
  43. style.height = uni_modules_uviewPlus_libs_function_index.addUnit(this.height);
  44. style.borderRadius = this.shape == "circle" ? "10000px" : uni_modules_uviewPlus_libs_function_index.addUnit(this.radius);
  45. style.overflow = this.radius > 0 ? "hidden" : "visible";
  46. return uni_modules_uviewPlus_libs_function_index.deepMerge(style, uni_modules_uviewPlus_libs_function_index.addStyle(this.customStyle));
  47. }
  48. },
  49. mounted() {
  50. this.show = true;
  51. },
  52. emits: ["click", "error", "load"],
  53. methods: {
  54. addUnit: uni_modules_uviewPlus_libs_function_index.addUnit,
  55. // 点击图片
  56. onClick() {
  57. this.$emit("click");
  58. },
  59. // 图片加载失败
  60. onErrorHandler(err) {
  61. this.loading = false;
  62. this.isError = true;
  63. this.$emit("error", err);
  64. },
  65. // 图片加载完成,标记loading结束
  66. onLoadHandler(event) {
  67. this.loading = false;
  68. this.isError = false;
  69. this.$emit("load", event);
  70. this.removeBgColor();
  71. },
  72. // 移除图片的背景色
  73. removeBgColor() {
  74. this.backgroundStyle = {
  75. backgroundColor: "transparent"
  76. };
  77. }
  78. }
  79. };
  80. if (!Array) {
  81. const _easycom_u_icon2 = common_vendor.resolveComponent("u-icon");
  82. const _easycom_u_transition2 = common_vendor.resolveComponent("u-transition");
  83. (_easycom_u_icon2 + _easycom_u_transition2)();
  84. }
  85. const _easycom_u_icon = () => "../u-icon/u-icon.js";
  86. const _easycom_u_transition = () => "../u-transition/u-transition.js";
  87. if (!Math) {
  88. (_easycom_u_icon + _easycom_u_transition)();
  89. }
  90. function _sfc_render(_ctx, _cache, $props, $setup, $data, $options) {
  91. return common_vendor.e({
  92. a: !$data.isError
  93. }, !$data.isError ? {
  94. b: _ctx.src,
  95. c: _ctx.mode,
  96. d: common_vendor.o((...args) => $options.onErrorHandler && $options.onErrorHandler(...args)),
  97. e: common_vendor.o((...args) => $options.onLoadHandler && $options.onLoadHandler(...args)),
  98. f: _ctx.showMenuByLongpress,
  99. g: _ctx.lazyLoad,
  100. h: _ctx.shape == "circle" ? "10000px" : $options.addUnit(_ctx.radius),
  101. i: $options.addUnit(_ctx.width),
  102. j: $options.addUnit(_ctx.height)
  103. } : {}, {
  104. k: _ctx.showLoading && $data.loading
  105. }, _ctx.showLoading && $data.loading ? {
  106. l: common_vendor.p({
  107. name: _ctx.loadingIcon,
  108. width: _ctx.width,
  109. height: _ctx.height
  110. }),
  111. m: _ctx.shape == "circle" ? "50%" : $options.addUnit(_ctx.radius),
  112. n: this.bgColor,
  113. o: $options.addUnit(_ctx.width),
  114. p: $options.addUnit(_ctx.height)
  115. } : {}, {
  116. q: _ctx.showError && $data.isError && !$data.loading
  117. }, _ctx.showError && $data.isError && !$data.loading ? {
  118. r: common_vendor.p({
  119. name: _ctx.errorIcon,
  120. width: _ctx.width,
  121. height: _ctx.height
  122. }),
  123. s: _ctx.shape == "circle" ? "50%" : $options.addUnit(_ctx.radius),
  124. t: $options.addUnit(_ctx.width),
  125. v: $options.addUnit(_ctx.height)
  126. } : {}, {
  127. w: common_vendor.o((...args) => $options.onClick && $options.onClick(...args)),
  128. x: common_vendor.s($options.wrapStyle),
  129. y: common_vendor.s($data.backgroundStyle),
  130. z: common_vendor.p({
  131. mode: "fade",
  132. show: $data.show,
  133. duration: _ctx.fade ? 1e3 : 0
  134. })
  135. });
  136. }
  137. const Component = /* @__PURE__ */ common_vendor._export_sfc(_sfc_main, [["render", _sfc_render], ["__scopeId", "data-v-abebd402"]]);
  138. wx.createComponent(Component);