冬天的太阳
冬天的太阳
  • 发布:2024-01-11 11:32
  • 更新:2024-01-15 14:04
  • 阅读:137

【报Bug】udb组件嵌套,里层组件数据不更新

分类:uni-app

产品分类: uniapp/小程序/微信

PC开发环境操作系统: Mac

PC开发环境操作系统版本号: 13.6

HBuilderX类型: 正式

HBuilderX版本号: 3.99

第三方开发者工具版本号: 最新

基础库版本号: 最新

项目创建方式: HBuilderX

示例代码:
<unicloud-db ref="udbSum" v-slot:default="{data, loading, error, options}" collection="pay"  
            :where="`pay_date > ${selectDateStart} && pay_date < ${selectDateEnd} && openid == '${userInfo.openid}' && is_remove == 0`"  
            groupby="openid" group-field="sum(pay_num) as payMonthSum" loadtime="manual">  
            <view  
                class="month-pay main-margin-top mian-box-shadow bg-white main-border-radius flex justify-center align-center">  
                <text class="text14px">¥</text>  
                <text class="text30px text-bold" v-if="data.length > 0">{{data[0].payMonthSum / 1000}}</text>  
                <text class="text30px text-bold" v-else>0</text>  
            </view>  
        </unicloud-db>  
        <unicloud-db ref="udb" v-slot:default="{data, loading, error, options}" collection="pay"  
            :where="`pay_date > ${selectDateStart} && pay_date < ${selectDateEnd} && openid == '${userInfo.openid}' && is_remove == 0`"  
            groupby="pay_date" group-field="sum(pay_num) as payDaySum" orderby="pay_date desc" loadtime="manual">  
            <!-- 循环日期 -->  
            <view class="detail-list" v-for="(item,index) in data" :key="index" v-after>  
                <view class="detail-date flex align-center">  
                    <uni-dateformat :date="item.pay_date" format="yyyy-MM-dd"></uni-dateformat>  
                    <view class="body-padding">(¥{{item.payDaySum / 1000}})</view>  
                </view>  
                <view class="day-pay bg-white main-margin-top mian-box-shadow main-border-radius">  
                    <unicloud-db v-slot:default="{data, loading, error, options}" v-if="data"  
                        collection="pay, pay-type"  
                        :where="`pay_date == ${item.pay_date} && openid == '${userInfo.openid}' && is_remove == 0`"  
                        orderby="pay_date" loadtime="auto">  
                        <!-- 每日消费详细 -->  
                        <view class="day-pay-detail flex justify-between main-padding-top-down body-padding main-border-bottom"  
                            v-for="(item1,index) in data" :key="index">  
                            <text>{{item1.pay_type[0].type_name}}</text><text>¥{{item1.pay_num / 1000}}</text>  
                        </view>  
                        <!-- 每日消费明细结束 -->  
                    </unicloud-db>  
                </view>  
            </view>  
            <!-- 循环日期结束 -->  
        </unicloud-db>  

<script steup>  
// 重新加载数据  
    function udbloadData() {  
        udb.value.loadData({  
            clear: true  
        })  
        udbSum.value.loadData({  
            clear: true  
        })  
    }  

    // 日期选择  
    function pickerDateChange(e) {  
        selectDate.value = e.detail.value  
    }  

    // 前往记一笔页面  
    function toNewView() {  
        uni.navigateTo({  
            url: '/pages/index/new/new'  
        })  
    }  

    onReady(() => {  
        udbloadData()  
    })  

    onShow(() => {  
        udbloadData()  
    })  
</script>

操作步骤:
<unicloud-db ref="udbSum" v-slot:default="{data, loading, error, options}" collection="pay"  
            :where="`pay_date > ${selectDateStart} && pay_date < ${selectDateEnd} && openid == '${userInfo.openid}' && is_remove == 0`"  
            groupby="openid" group-field="sum(pay_num) as payMonthSum" loadtime="manual">  
            <view  
                class="month-pay main-margin-top mian-box-shadow bg-white main-border-radius flex justify-center align-center">  
                <text class="text14px">¥</text>  
                <text class="text30px text-bold" v-if="data.length > 0">{{data[0].payMonthSum / 1000}}</text>  
                <text class="text30px text-bold" v-else>0</text>  
            </view>  
        </unicloud-db>  
        <unicloud-db ref="udb" v-slot:default="{data, loading, error, options}" collection="pay"  
            :where="`pay_date > ${selectDateStart} && pay_date < ${selectDateEnd} && openid == '${userInfo.openid}' && is_remove == 0`"  
            groupby="pay_date" group-field="sum(pay_num) as payDaySum" orderby="pay_date desc" loadtime="manual">  
            <!-- 循环日期 -->  
            <view class="detail-list" v-for="(item,index) in data" :key="index" v-after>  
                <view class="detail-date flex align-center">  
                    <uni-dateformat :date="item.pay_date" format="yyyy-MM-dd"></uni-dateformat>  
                    <view class="body-padding">(¥{{item.payDaySum / 1000}})</view>  
                </view>  
                <view class="day-pay bg-white main-margin-top mian-box-shadow main-border-radius">  
                    <unicloud-db v-slot:default="{data, loading, error, options}" v-if="data"  
                        collection="pay, pay-type"  
                        :where="`pay_date == ${item.pay_date} && openid == '${userInfo.openid}' && is_remove == 0`"  
                        orderby="pay_date" loadtime="auto">  
                        <!-- 每日消费详细 -->  
                        <view class="day-pay-detail flex justify-between main-padding-top-down body-padding main-border-bottom"  
                            v-for="(item1,index) in data" :key="index">  
                            <text>{{item1.pay_type[0].type_name}}</text><text>¥{{item1.pay_num / 1000}}</text>  
                        </view>  
                        <!-- 每日消费明细结束 -->  
                    </unicloud-db>  
                </view>  
            </view>  
            <!-- 循环日期结束 -->  
        </unicloud-db>  

<script steup>  
// 重新加载数据  
    function udbloadData() {  
        udb.value.loadData({  
            clear: true  
        })  
        udbSum.value.loadData({  
            clear: true  
        })  
    }  

    // 日期选择  
    function pickerDateChange(e) {  
        selectDate.value = e.detail.value  
    }  

    // 前往记一笔页面  
    function toNewView() {  
        uni.navigateTo({  
            url: '/pages/index/new/new'  
        })  
    }  

    onReady(() => {  
        udbloadData()  
    })  

    onShow(() => {  
        udbloadData()  
    })  
</script>

预期结果:

里层数据更新

实际结果:

里层数据没有更新

bug描述:

udb组件嵌套,里层组件数据不更新。 里层组件where依赖外部组件循环出来的值, 页面第一次加载数据正常显示, 当添加数据后返回页面,外层数据可以正常更新,但是里层数据不会更新

2024-01-11 11:32 负责人:无 分享
已邀请:

要回复问题请先登录注册