index.vue 7.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152
  1. <template>
  2. <view class="zs-img-box">
  3. <view class="border-box" v-if="border">
  4. <image class="border" v-if="border == 'border1'" src="../../static/border1.png" mode=""></image>
  5. <image class="border" v-else-if="border == 'border2'" src="../../static/border2.png" mode=""></image>
  6. <image class="border" v-else-if="border == 'border3'" src="../../static/border3.png" mode=""></image>
  7. <view class="title" :class="[border == 'border1'?'title1':'',border == 'border2'?'title2':'',border == 'border3'?'title3':'',]">
  8. 官方认证
  9. </view>
  10. <view class="sub-title">
  11. 满200享7折
  12. </view>
  13. <view class="type" :class="[border == 'border1'?'type1':'',border == 'border2'?'type2':'',border == 'border3'?'type3':'',]">
  14. 优选
  15. </view>
  16. </view>
  17. <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>
  18. <image v-else :style="{width,height,borderRadius:radius == 'full'?'16rpx':'16rpx 16rpx 0 0' }" :src="defaultSrc" :mode='mode'></image>
  19. </view>
  20. </template>
  21. <script>
  22. import guid from '@/utils/guid.js'
  23. export default {
  24. props: {
  25. src: {
  26. type: String,
  27. default:''
  28. },
  29. width: {
  30. type: String,
  31. default: '100rpx'
  32. },
  33. height: {
  34. type: String,
  35. default: '100rpx'
  36. },
  37. radius:{
  38. type: String,
  39. default: 'half'
  40. },
  41. mode:{
  42. type: String,
  43. default: ''
  44. },
  45. border:{
  46. type: String,
  47. default: ''
  48. },
  49. },
  50. data() {
  51. return {
  52. elIndex: guid(),
  53. Observer:null,
  54. defaultSrc:'',
  55. imgSrc:require('../../static/img-loading.png'),
  56. isError:false
  57. }
  58. },
  59. watch: {
  60. src(val,old) {
  61. if(val != old){
  62. this.url1 = val
  63. }
  64. }
  65. },
  66. computed: {
  67. url1:{
  68. get:function(){
  69. return this.imgSrc
  70. },
  71. set:function(val){
  72. this.imgSrc = val
  73. }
  74. }
  75. },
  76. methods: {
  77. error() {
  78. console.log('报错了');
  79. this.isError = true
  80. }
  81. },
  82. onReady() {
  83. this.Observer = uni.createIntersectionObserver(this)
  84. this.Observer.relativeToViewport({bottom: -100}).observe('.lazy' + this.elIndex, (res) => {
  85. this.url1 = this.src
  86. })
  87. },
  88. beforeDestroy() {
  89. // this.Observer.disconnect()
  90. }
  91. }
  92. </script>
  93. <style lang="scss" scoped>
  94. .zs-img-box{
  95. position: relative;
  96. .border-box{
  97. position: absolute;
  98. top: 0%;
  99. left: 0;
  100. width: 100%;
  101. height: 100%;
  102. font-weight: bold;
  103. .border{
  104. width: 100%;
  105. height: 100%;
  106. }
  107. .title{
  108. color: #fff;
  109. font-size: 28rpx;
  110. text-align: center;
  111. position: absolute;
  112. top: 0%;
  113. left: 0;
  114. width: 100%;
  115. text-align: center;
  116. }
  117. .title3{
  118. text-align: left;
  119. padding-left: 20rpx;
  120. }
  121. .sub-title{
  122. color: #fff;
  123. font-size: 24rpx;
  124. text-align: center;
  125. position: absolute;
  126. bottom: 6rpx;
  127. left: 0;
  128. text-indent: 120rpx;
  129. }
  130. .type{
  131. color: #fff;
  132. font-size: 36rpx;
  133. text-align: center;
  134. position: absolute;
  135. bottom: 6rpx;
  136. left: 6rpx;
  137. }
  138. .type1{
  139. color: rgba(38, 72, 162, 1);
  140. }
  141. }
  142. .img1{
  143. vertical-align: middle;
  144. width: 50px;
  145. }
  146. }
  147. </style>