index.vue 6.2 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889
  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. },
  33. data() {
  34. return {
  35. elIndex: guid(),
  36. Observer:null,
  37. defaultSrc:'',
  38. imgSrc:require('../../static/img-loading.png'),
  39. isError:false
  40. }
  41. },
  42. watch: {
  43. src(val,old) {
  44. if(val != old){
  45. this.isError = false
  46. this.url1 = val
  47. }
  48. }
  49. },
  50. computed: {
  51. url1:{
  52. get:function(){
  53. return this.imgSrc
  54. },
  55. set:function(val){
  56. this.imgSrc = val
  57. }
  58. }
  59. },
  60. methods: {
  61. error() {
  62. this.isError = true
  63. }
  64. },
  65. onReady() {
  66. this.Observer = uni.createIntersectionObserver(this)
  67. this.Observer.relativeToViewport({bottom: -50}).observe('.lazy' + this.elIndex, (res) => {
  68. let width = this.width.replace('rpx','')
  69. this.url1 = this.src +'?x-oss-process=image/resize,w_'+ Math.ceil(rpxTopx(width))
  70. })
  71. },
  72. beforeDestroy() {
  73. this.Observer&&this.Observer.disconnect()
  74. }
  75. }
  76. </script>
  77. <style lang="scss" scoped>
  78. .zs-img-box{
  79. position: relative;
  80. image{
  81. vertical-align: bottom;
  82. }
  83. }
  84. </style>