index.vue 6.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899
  1. <template>
  2. <view class="zs-img-box">
  3. <image class="img1" v-if="!isError" :class="'lazy' + elIndex" :style="{width,height,borderRadius:radius == 'full'?'16rpx':'16rpx 16rpx 0 0' }" :src="url1" :mode='mode' @error="error"></image>
  4. <image v-else :style="{width,height,borderRadius:radius == 'full'?'16rpx':'16rpx 16rpx 0 0' }" :src="defaultSrc" :mode='mode'></image>
  5. </view>
  6. </template>
  7. <script>
  8. import guid from '@/utils/guid.js';
  9. import {rpxTopx} from '@/utils/tool.js'
  10. export default {
  11. props: {
  12. src: {
  13. type: String,
  14. default:''
  15. },
  16. width: {
  17. type: String,
  18. default: '100rpx'
  19. },
  20. height: {
  21. type: String,
  22. default: '100rpx'
  23. },
  24. radius:{
  25. type: String,
  26. default: 'half'
  27. },
  28. mode:{
  29. type: String,
  30. default: ''
  31. },
  32. type:{
  33. type: String,
  34. default: ''
  35. },
  36. },
  37. data() {
  38. return {
  39. elIndex: guid(),
  40. Observer:null,
  41. // defaultSrc:'',
  42. defaultSrc:require('../../static/error-img.png'),
  43. imgSrc:require('../../static/loading-img.png'),
  44. isError:false
  45. }
  46. },
  47. watch: {
  48. src(val,old) {
  49. if(val != old){
  50. this.isError = false
  51. this.url1 = val
  52. }
  53. }
  54. },
  55. computed: {
  56. url1:{
  57. get:function(){
  58. return this.imgSrc
  59. },
  60. set:function(val){
  61. this.imgSrc = val
  62. }
  63. }
  64. },
  65. methods: {
  66. error() {
  67. this.isError = true
  68. }
  69. },
  70. onReady() {
  71. this.Observer = uni.createIntersectionObserver(this)
  72. this.Observer.relativeToViewport({bottom: -50}).observe('.lazy' + this.elIndex, (res) => {
  73. if(this.type != 'hotel'){
  74. let width = this.width.replace('rpx','')
  75. this.url1 = this.src +'?x-oss-process=image/resize,w_'+ (Math.ceil(rpxTopx(width))*2 )
  76. }else{
  77. this.url1 = this.src
  78. }
  79. })
  80. },
  81. beforeDestroy() {
  82. this.Observer&&this.Observer.disconnect()
  83. }
  84. }
  85. </script>
  86. <style lang="scss" scoped>
  87. .zs-img-box{
  88. position: relative;
  89. image{
  90. vertical-align: bottom;
  91. will-change: transform
  92. }
  93. }
  94. </style>