| <template> | 
|     <view class="uni-load-more" @click="onClick"> | 
|         <!-- #ifdef APP-NVUE --> | 
|         <loading-indicator v-if="!webviewHide && status === 'loading' && showIcon" | 
|             :style="{color: color,width:iconSize+'px',height:iconSize+'px'}" :animating="true" | 
|             class="uni-load-more__img uni-load-more__img--nvue"></loading-indicator> | 
|         <!-- #endif --> | 
|         <!-- #ifdef H5 --> | 
|         <svg width="24" height="24" viewBox="25 25 50 50" | 
|             v-if="!webviewHide && (iconType==='circle' || iconType==='auto' && platform === 'android') && status === 'loading' && showIcon" | 
|             :style="{width:iconSize+'px',height:iconSize+'px'}" | 
|             class="uni-load-more__img uni-load-more__img--android-H5"> | 
|             <circle cx="50" cy="50" r="20" fill="none" :style="{color:color}" :stroke-width="3"></circle> | 
|         </svg> | 
|         <!-- #endif --> | 
|         <!-- #ifndef APP-NVUE || H5 --> | 
|         <view | 
|             v-if="!webviewHide && (iconType==='circle' || iconType==='auto' && platform === 'android') && status === 'loading' && showIcon" | 
|             :style="{width:iconSize+'px',height:iconSize+'px'}" | 
|             class="uni-load-more__img uni-load-more__img--android-MP"> | 
|             <view class="uni-load-more__img-icon" :style="{borderTopColor:color,borderTopWidth:iconSize/12}"></view> | 
|             <view class="uni-load-more__img-icon" :style="{borderTopColor:color,borderTopWidth:iconSize/12}"></view> | 
|             <view class="uni-load-more__img-icon" :style="{borderTopColor:color,borderTopWidth:iconSize/12}"></view> | 
|         </view> | 
|         <!-- #endif --> | 
|         <!-- #ifndef APP-NVUE --> | 
|         <view v-else-if="!webviewHide && status === 'loading' && showIcon" | 
|             :style="{width:iconSize+'px',height:iconSize+'px'}" class="uni-load-more__img uni-load-more__img--ios-H5"> | 
|             <image :src="imgBase64" mode="widthFix"></image> | 
|         </view> | 
|         <!-- #endif --> | 
|         <text v-if="showText" class="uni-load-more__text" | 
|             :style="{color: color}">{{ status === 'more' ? contentdownText : status === 'loading' ? contentrefreshText : contentnomoreText }}</text> | 
|     </view> | 
| </template> | 
|   | 
| <script> | 
|     let platform | 
|     setTimeout(() => { | 
|         platform = uni.getSystemInfoSync().platform | 
|     }, 16) | 
|   | 
|     import { | 
|         initVueI18n | 
|     } from '@dcloudio/uni-i18n' | 
|     import messages from './i18n/index.js' | 
|     const { | 
|         t | 
|     } = initVueI18n(messages) | 
|   | 
|     /** | 
|      * LoadMore 加载更多 | 
|      * @description 用于列表中,做滚动加载使用,展示 loading 的各种状态 | 
|      * @tutorial https://ext.dcloud.net.cn/plugin?id=29 | 
|      * @property {String} status = [more|loading|noMore] loading 的状态 | 
|      *     @value more loading前 | 
|      *     @value loading loading中 | 
|      *     @value noMore 没有更多了 | 
|      * @property {Number} iconSize 指定图标大小 | 
|      * @property {Boolean} iconSize = [true|false] 是否显示 loading 图标 | 
|      * @property {String} iconType = [snow|circle|auto] 指定图标样式 | 
|      *     @value snow ios雪花加载样式 | 
|      *     @value circle 安卓唤醒加载样式 | 
|      *     @value auto 根据平台自动选择加载样式 | 
|      * @property {String} color 图标和文字颜色 | 
|      * @property {Object} contentText 各状态文字说明,值为:{contentdown: "上拉显示更多",contentrefresh: "正在加载...",contentnomore: "没有更多数据了"} | 
|      * @event {Function} clickLoadMore 点击加载更多时触发 | 
|      */ | 
|     export default { | 
|         name: 'UniLoadMore', | 
|         emits: ['clickLoadMore'], | 
|         props: { | 
|             status: { | 
|                 // 上拉的状态:more-loading前;loading-loading中;noMore-没有更多了 | 
|                 type: String, | 
|                 default: 'more' | 
|             }, | 
|             showIcon: { | 
|                 type: Boolean, | 
|                 default: true | 
|             }, | 
|             iconType: { | 
|                 type: String, | 
|                 default: 'auto' | 
|             }, | 
|             iconSize: { | 
|                 type: Number, | 
|                 default: 24 | 
|             }, | 
|             color: { | 
|                 type: String, | 
|                 default: '#777777' | 
|             }, | 
|             contentText: { | 
|                 type: Object, | 
|                 default () { | 
|                     return { | 
|                         contentdown: '', | 
|                         contentrefresh: '', | 
|                         contentnomore: '' | 
|                     } | 
|                 } | 
|             }, | 
|             showText: { | 
|                 type: Boolean, | 
|                 default: true | 
|             } | 
|         }, | 
|         data() { | 
|             return { | 
|                 webviewHide: false, | 
|                 platform: platform, | 
|                 imgBase64: '' | 
|             } | 
|         }, | 
|         computed: { | 
|             iconSnowWidth() { | 
|                 return (Math.floor(this.iconSize / 24) || 1) * 2 | 
|             }, | 
|             contentdownText() { | 
|                 return this.contentText.contentdown || t("uni-load-more.contentdown") | 
|             }, | 
|             contentrefreshText() { | 
|                 return this.contentText.contentrefresh || t("uni-load-more.contentrefresh") | 
|             }, | 
|             contentnomoreText() { | 
|                 return this.contentText.contentnomore || t("uni-load-more.contentnomore") | 
|             } | 
|         }, | 
|         mounted() { | 
|             // #ifdef APP-PLUS | 
|             var pages = getCurrentPages(); | 
|             var page = pages[pages.length - 1]; | 
|             var currentWebview = page.$getAppWebview(); | 
|             currentWebview.addEventListener('hide', () => { | 
|                 this.webviewHide = true | 
|             }) | 
|             currentWebview.addEventListener('show', () => { | 
|                 this.webviewHide = false | 
|             }) | 
|             // #endif | 
|         }, | 
|         methods: { | 
|             onClick() { | 
|                 this.$emit('clickLoadMore', { | 
|                     detail: { | 
|                         status: this.status, | 
|                     } | 
|                 }) | 
|             } | 
|         } | 
|     } | 
| </script> | 
|   | 
| <style lang="scss" > | 
|     .uni-load-more { | 
|         /* #ifndef APP-NVUE */ | 
|         display: flex; | 
|         /* #endif */ | 
|         flex-direction: row; | 
|         height: 40px; | 
|         align-items: center; | 
|         justify-content: center; | 
|     } | 
|   | 
|     .uni-load-more__text { | 
|         font-size: 14px; | 
|         margin-left: 8px; | 
|     } | 
|   | 
|     .uni-load-more__img { | 
|         width: 24px; | 
|         height: 24px; | 
|         // margin-right: 8px; | 
|     } | 
|   | 
|     .uni-load-more__img--nvue { | 
|         color: #666666; | 
|     } | 
|   | 
|     .uni-load-more__img--android, | 
|     .uni-load-more__img--ios { | 
|         width: 24px; | 
|         height: 24px; | 
|         transform: rotate(0deg); | 
|     } | 
|   | 
|     /* #ifndef APP-NVUE */ | 
|     .uni-load-more__img--android { | 
|         animation: loading-ios 1s 0s linear infinite; | 
|     } | 
|   | 
|     @keyframes loading-android { | 
|         0% { | 
|             transform: rotate(0deg); | 
|         } | 
|   | 
|         100% { | 
|             transform: rotate(360deg); | 
|         } | 
|     } | 
|   | 
|     .uni-load-more__img--ios-H5 { | 
|         position: relative; | 
|         animation: loading-ios-H5 1s 0s step-end infinite; | 
|     } | 
|   | 
|     .uni-load-more__img--ios-H5 image { | 
|         position: absolute; | 
|         width: 100%; | 
|         height: 100%; | 
|         left: 0; | 
|         top: 0; | 
|     } | 
|   | 
|     @keyframes loading-ios-H5 { | 
|         0% { | 
|             transform: rotate(0deg); | 
|         } | 
|   | 
|         8% { | 
|             transform: rotate(30deg); | 
|         } | 
|   | 
|         16% { | 
|             transform: rotate(60deg); | 
|         } | 
|   | 
|         24% { | 
|             transform: rotate(90deg); | 
|         } | 
|   | 
|         32% { | 
|             transform: rotate(120deg); | 
|         } | 
|   | 
|         40% { | 
|             transform: rotate(150deg); | 
|         } | 
|   | 
|         48% { | 
|             transform: rotate(180deg); | 
|         } | 
|   | 
|         56% { | 
|             transform: rotate(210deg); | 
|         } | 
|   | 
|         64% { | 
|             transform: rotate(240deg); | 
|         } | 
|   | 
|         73% { | 
|             transform: rotate(270deg); | 
|         } | 
|   | 
|         82% { | 
|             transform: rotate(300deg); | 
|         } | 
|   | 
|         91% { | 
|             transform: rotate(330deg); | 
|         } | 
|   | 
|         100% { | 
|             transform: rotate(360deg); | 
|         } | 
|     } | 
|   | 
|     /* #endif */ | 
|   | 
|     /* #ifdef H5 */ | 
|     .uni-load-more__img--android-H5 { | 
|         animation: loading-android-H5-rotate 2s linear infinite; | 
|         transform-origin: center center; | 
|     } | 
|   | 
|     .uni-load-more__img--android-H5 circle { | 
|         display: inline-block; | 
|         animation: loading-android-H5-dash 1.5s ease-in-out infinite; | 
|         stroke: currentColor; | 
|         stroke-linecap: round; | 
|     } | 
|   | 
|     @keyframes loading-android-H5-rotate { | 
|         0% { | 
|             transform: rotate(0deg); | 
|         } | 
|   | 
|         100% { | 
|             transform: rotate(360deg); | 
|         } | 
|     } | 
|   | 
|     @keyframes loading-android-H5-dash { | 
|         0% { | 
|             stroke-dasharray: 1, 200; | 
|             stroke-dashoffset: 0; | 
|         } | 
|   | 
|         50% { | 
|             stroke-dasharray: 90, 150; | 
|             stroke-dashoffset: -40; | 
|         } | 
|   | 
|         100% { | 
|             stroke-dasharray: 90, 150; | 
|             stroke-dashoffset: -120; | 
|         } | 
|     } | 
|   | 
|     /* #endif */ | 
|   | 
|     /* #ifndef APP-NVUE || H5 */ | 
|     .uni-load-more__img--android-MP { | 
|         position: relative; | 
|         width: 24px; | 
|         height: 24px; | 
|         transform: rotate(0deg); | 
|         animation: loading-ios 1s 0s ease infinite; | 
|     } | 
|   | 
|     .uni-load-more__img--android-MP .uni-load-more__img-icon { | 
|         position: absolute; | 
|         box-sizing: border-box; | 
|         width: 100%; | 
|         height: 100%; | 
|         border-radius: 50%; | 
|         border: solid 2px transparent; | 
|         border-top: solid 2px #777777; | 
|         transform-origin: center; | 
|     } | 
|   | 
|     .uni-load-more__img--android-MP .uni-load-more__img-icon:nth-child(1) { | 
|         animation: loading-android-MP-1 1s 0s linear infinite; | 
|     } | 
|   | 
|     .uni-load-more__img--android-MP .uni-load-more__img-icon:nth-child(2) { | 
|         animation: loading-android-MP-2 1s 0s linear infinite; | 
|     } | 
|   | 
|     .uni-load-more__img--android-MP .uni-load-more__img-icon:nth-child(3) { | 
|         animation: loading-android-MP-3 1s 0s linear infinite; | 
|     } | 
|   | 
|     @keyframes loading-android { | 
|         0% { | 
|             transform: rotate(0deg); | 
|         } | 
|   | 
|         100% { | 
|             transform: rotate(360deg); | 
|         } | 
|     } | 
|   | 
|     @keyframes loading-android-MP-1 { | 
|         0% { | 
|             transform: rotate(0deg); | 
|         } | 
|   | 
|         50% { | 
|             transform: rotate(90deg); | 
|         } | 
|   | 
|         100% { | 
|             transform: rotate(360deg); | 
|         } | 
|     } | 
|   | 
|     @keyframes loading-android-MP-2 { | 
|         0% { | 
|             transform: rotate(0deg); | 
|         } | 
|   | 
|         50% { | 
|             transform: rotate(180deg); | 
|         } | 
|   | 
|         100% { | 
|             transform: rotate(360deg); | 
|         } | 
|     } | 
|   | 
|     @keyframes loading-android-MP-3 { | 
|         0% { | 
|             transform: rotate(0deg); | 
|         } | 
|   | 
|         50% { | 
|             transform: rotate(270deg); | 
|         } | 
|   | 
|         100% { | 
|             transform: rotate(360deg); | 
|         } | 
|     } | 
|   | 
|     /* #endif */ | 
| </style> |