index.vue 6.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687
  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. export default {
  10. props: {
  11. src: {
  12. type: String,
  13. default:''
  14. },
  15. width: {
  16. type: String,
  17. default: '100rpx'
  18. },
  19. height: {
  20. type: String,
  21. default: '100rpx'
  22. },
  23. radius:{
  24. type: String,
  25. default: 'half'
  26. },
  27. mode:{
  28. type: String,
  29. default: ''
  30. },
  31. },
  32. data() {
  33. return {
  34. elIndex: guid(),
  35. Observer:null,
  36. defaultSrc:'',
  37. imgSrc:require('../../static/img-loading.png'),
  38. isError:false
  39. }
  40. },
  41. watch: {
  42. src(val,old) {
  43. if(val != old){
  44. this.isError = false
  45. this.url1 = val
  46. }
  47. }
  48. },
  49. computed: {
  50. url1:{
  51. get:function(){
  52. return this.imgSrc
  53. },
  54. set:function(val){
  55. this.imgSrc = val
  56. }
  57. }
  58. },
  59. methods: {
  60. error() {
  61. this.isError = true
  62. }
  63. },
  64. onReady() {
  65. this.Observer = uni.createIntersectionObserver(this)
  66. this.Observer.relativeToViewport({bottom: -50}).observe('.lazy' + this.elIndex, (res) => {
  67. this.url1 = this.src
  68. })
  69. },
  70. beforeDestroy() {
  71. this.Observer.disconnect()
  72. }
  73. }
  74. </script>
  75. <style lang="scss" scoped>
  76. .zs-img-box{
  77. position: relative;
  78. image{
  79. vertical-align: bottom;
  80. }
  81. }
  82. </style>