datacom.uvue 2.1 KB
Newer Older
H
hdx 已提交
1 2 3 4 5 6 7 8 9
<template>
  <view>
    <view v-if="mixinDatacomLoading">Loading...</view>
    <view v-else-if="mixinDatacomError">
      请求错误:{{mixinDatacomError}}
    </view>
    <view v-else="mixinDatacomResData.length>0">
      <!-- 需要自行处理数据及相关UI展现 -->
      <!-- {{mixinDatacomResData}} -->
雪洛's avatar
雪洛 已提交
10 11
      <scroll-view class="list-view">
        <view class="list-item" v-for="(item, _) in mixinDatacomResData">
H
hdx 已提交
12
          <text>{{item}}</text>
雪洛's avatar
雪洛 已提交
13 14
        </view>
      </scroll-view>
H
hdx 已提交
15
    </view>
16 17 18
    <view v-if="!mixinDatacomLoading && mixinDatacomResData.length==0">
      无数据
    </view>
H
hdx 已提交
19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42
  </view>
</template>

<script lang="uts">
  export default {
    mixins: [uniCloud.mixinDatacom],
    data() {
      return {
      }
    },
    created() {
      this.load()
    },
    methods: {
      load() {
        if (this.mixinDatacomLoading == true) {
          return
        }
        this.mixinDatacomLoading = true

        this.mixinDatacomGet(null).then((res: UniCloudDBGetResult) => {
          const data = res.data
          // const count = res.count
          this.mixinDatacomResData = data
43
        }).catch((err: any | null) => {
H
hdx 已提交
44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70
          this.mixinDatacomError = err as UniCloudError
        }).finally(() => {
          this.mixinDatacomLoading = false
        })
      },
      // 当组件属性发生变化时
      onMixinDatacomPropsChange(needReset: boolean, changed: Array<string>) {
        console.log(needReset, changed);
        // needReset=true 需要重置已加载数据和分页信息,例如 collection,orderby
        // changed,变化的属性名,类型为 Array,例如 ['collection', 'orderby']
        // if (needReset) {
        //   // 清空已加载的数据
        //   this.mixinDatacomResData = []

        //   // 重置分页数据,如果没有分页不需要处理
        //   this.mixinDatacomPage.size = this.pageSize // 重置分页大小
        //   this.mixinDatacomPage.current = 0 // 重置当前分页
        //   this.mixinDatacomPage.count = 0 // 重置数据总数
        // }
      }
    }
  }
</script>

<style>

</style>