关于uniapp:用uniapp写一个内外循环的全选与反选不会的赶紧围观

49次阅读

共计 7917 个字符,预计需要花费 20 分钟才能阅读完成。


依据我的项目需要;写的一个内外循环的全选与反选;遇到问题:因为是分页,抉择全选,当上拉加载时;新加载的数据并没有被选中等问题,都被解决;如果有其余些问题;欢送提出。

留神:这只我我的项目中的页面;有些全局援用的例如提醒或是一些组件;应用的时候能够删除;并不影响次要性能;获取数据时;因为后盾传的是认为数组;但理论须要的二维数据;上面获取数据的接口曾经过解决;依据你们返回的数据格式可自行更改;咱们我的项目中有一键换色;牵扯到色彩变量的可删除;写成固定色彩
以下是具体代码:

Html:<template>
    <view>
        <view class="record" :style="colorStyle" v-if="visitList.length">
            <view class="nav acea-row row-between-wrapper">
                <view class="left"> 以后共 <text class="num">{{count}}</text> 件商品 </view>
                <view class="font-num" v-if="!isShowChecked" @click="switchTap"> 治理 </view>
                <view v-else @click="switchTap"> 勾销 </view>
            </view>
            <view class="list">
                <checkbox-group @change="checkboxChange">
                    <view class="item" v-for="(item,index) in visitList" :key="index">
                        <view class="title">
                            <checkbox v-if="isShowChecked" :value="item.time" :checked="item.checked" />
                            <text>{{item.time}}</text>
                        </view>
                        <checkbox-group @change="(e)=>{picCheckbox(e,index)}">
                            <view class="picList acea-row row-middle">
                                <view class="picTxt" v-for="(j,jindex) in item.picList" :key="jindex" @click.stop="goDetails(j)">
                                    <view class="pictrue">
                                        <image :src="j.image"></image>
                                        <checkbox v-if="isShowChecked" :value="(j.id).toString()" :checked="j.checked" class="checkbox" />
                                    </view>
                                    <view class="money">¥<text class="num">{{j.product_price}}</text></view>
                                </view>
                            </view>
                        </checkbox-group>
                    </view>
                </checkbox-group>
                <view class='loadingicon acea-row row-center-wrapper'>
                    <text class='loading iconfont icon-jiazai' :hidden='loading==false'></text>{{loadTitle}}
                </view>
            </view>
            <view class="footer acea-row row-between-wrapper" v-if="isShowChecked">
                <checkbox-group @change="checkboxAllChange">
                    <checkbox value="all" :checked="isAllSelect" />
                    <text class='checkAll'> 全选 </text>
                </checkbox-group>
                <view class="acea-row row-middle">
                    <view class="bnt acea-row row-center-wrapper" @click="collect"> 珍藏 </view>
                    <view class="bnt on acea-row row-center-wrapper" @click="del"> 删除 </view>
                </view>
            </view>
        </view>
        <view class='noCommodity' v-else-if="!visitList.length && page == 1">
            <view class='pictrue'>
                <image src='../../../static/images/noCollection.png'></image>
            </view>
            <recommend :hostProduct="hostProduct"></recommend>
        </view>
        <home v-if="navigation"></home>
    </view>
</template>

Js:<script>
    import {
        getVisitList,
        getProductHot,
        deleteVisitList,
        collectAdd
    } from '@/api/store.js';
    import {mapGetters} from "vuex";
    import {toLogin} from '@/libs/login.js';
    import recommend from '@/components/recommend';
    // #ifdef MP
    import authorize from '@/components/Authorize';
    // #endif
    import home from '@/components/home';
    import colors from '@/mixins/color.js'
    export default {
        components: {
            recommend,
            // #ifdef MP
            authorize,
            // #endif
            home
        },
        mixins: [colors],
        data() {
            return {
                isShowChecked: 0,
                count: 0,
                times: [],
                isAllSelect: false,
                hostProduct: [],
                loadTitle: '加载更多',
                loading: false,
                loadend: false,
                visitList: [],
                limit: 21,
                page: 1,
                isAuto: false, // 没有受权的不会主动受权
                isShowAuth: false, // 是否暗藏受权
                hotScroll: false,
                hotPage: 1,
                hotLimit: 10,
                isItemAll: []};
        },
        computed: mapGetters(['isLogin']),
        onLoad() {if (this.isLogin) {
                this.loadend = false;
                this.page = 1;
                this.visitList = [];
                this.get_user_visit_list();
                this.get_host_product();} else {toLogin();
            }
        },
        onShow() {this.times = [];
            this.loadend = false;
            this.page = 1;
            this.visitList = [];
            this.get_user_visit_list();},
        methods: {goDetails(item){if(this.isShowChecked) return false;
                uni.navigateTo({url: '/pages/goods_details/index?id=' + item.product_id})
            },
            switchTap(){this.isShowChecked = !this.isShowChecked;},
            collect(){let ids = [];
                this.visitList.forEach(item=>{
                    item.picList.forEach(j=>{if(j.checked){ids.push(j.id)
                        }
                    })
                })
                if(!ids.length){
                    return this.$util.Tips({title: '请抉择珍藏商品'});
                }
                collectAdd(ids).then(res=>{
                    return this.$util.Tips({title: res.msg});
                })
            },
            del(){let ids = [];
                this.visitList.forEach(item=>{
                    item.picList.forEach(j=>{if(j.checked){ids.push(j.id)
                        }
                    })
                })
                if(!ids.length){
                    return this.$util.Tips({title: '请抉择删除商品'});
                }
                deleteVisitList(ids).then(res=>{this.times = [];
                    this.loadend = false;
                    this.page = 1;
                    this.$set(this, 'visitList', []);
                    this.get_user_visit_list();
                    return this.$util.Tips({title: res.msg});
                })
            },
            picCheckbox(event, index) {
                let that = this,
                    picTime = event.detail.value;
                that.visitList[index].picList.forEach(j => {if (picTime.indexOf(j.id + '') !== -1) {j.checked = true;} else {j.checked = false;}
                })
                if(that.visitList[index].picList.length == picTime.length){that.visitList[index].checked = true;
                }else{that.visitList[index].checked = false;
                }
                let visitObj = [];
                that.visitList.forEach(item=>{if(item.checked){visitObj.push(item.time)
                    }else{if(visitObj.indexOf(item.time) !== -1){visitObj.remove(item.time);
                        }
                    }
                })
                if(visitObj.length == that.visitList.length){that.isAllSelect = true;}else{that.isAllSelect = false;}
            },
            checkboxChange(event) {
                let that = this,
                    timeList = event.detail.value;
                that.isItemAll = timeList;
                that.visitList.forEach((item, index) => {if (timeList.indexOf(item.time) !== -1) {item.checked = true;} else {item.checked = false;}
                    item.picList.forEach(j => {if (item.checked) {j.checked = true;} else {j.checked = false;}
                    })
                })
                if (timeList.length === that.visitList.length) {that.isAllSelect = true;} else {that.isAllSelect = false;}
            },
            forGoods(val) {
                let that = this;
                if (!that.visitList.length) return
                that.visitList.forEach((item) => {if (val) {item.checked = true;} else {item.checked = false;}
                    item.picList.forEach(j => {if (val) {j.checked = true;} else {j.checked = false;}
                    })
                })
            },
            checkboxAllChange(event) {
                let value = event.detail.value;
                if (value.length) {
                    this.isAllSelect = true;
                    this.forGoods(1)
                } else {
                    this.isAllSelect = false;
                    this.forGoods(0)
                }
            },
            // 受权敞开
            authColse: function(e) {this.isShowAuth = e},
            /**
             * 获取珍藏产品
             */
            get_user_visit_list: function() {
                let that = this;
                if (this.loading) return;
                if (this.loadend) return;
                that.loading = true;
                that.loadTitle = "";
                getVisitList({
                    page: that.page,
                    limit: that.limit
                }).then(res => {
                    this.count = res.data.count;
                    for (let i = 0; i < res.data.time.length; i++) {if (this.times.indexOf(res.data.time[i]) == -1) {this.times.push(res.data.time[i])
                            this.visitList.push({time: res.data.time[i],
                                picList: []})
                        }
                    }
                    for (let x = 0; x < this.times.length; x++) {this.visitList[x].checked = this.isAllSelect ? true : false;
                        for (let j = 0; j < res.data.list.length; j++) {if (this.times[x] === res.data.list[j].time_key) {if (this.isAllSelect) {res.data.list[j].checked = true;
                                } else {res.data.list[j].checked = false;
                                }
                                this.visitList[x].picList.push(res.data.list[j])
                            }
                        }
                    }
                    let loadend = res.data.list.length < that.limit;
                    that.loadend = loadend;
                    that.loadTitle = loadend ? '没有更多内容啦~' : '加载更多';
                    that.page = that.page + 1;
                    that.loading = false;
                }).catch(err => {
                    that.loading = false;
                    that.loadTitle = "加载更多";
                });
            },
            /**
             * 获取我的举荐
             */
            get_host_product: function() {
                let that = this;
                if (that.hotScroll) return
                getProductHot(
                    that.hotPage,
                    that.hotLimit,
                ).then(res => {
                    that.hotPage++
                    that.hotScroll = res.data.length < that.hotLimit
                    that.hostProduct = that.hostProduct.concat(res.data)
                });
            }
        },
        onReachBottom() {if (this.visitList.length) {this.get_user_visit_list();
            } else {this.get_host_product();
            }
        }
    }
</script>

Css:<style lang="scss">
    page {background-color: #fff;}

    .record .pictrue /deep/checkbox .uni-checkbox-input {background-color: rgba(0, 0, 0, 0.16);
    }
    
    .record .pictrue /deep/checkbox .wx-checkbox-input {background-color: rgba(0, 0, 0, 0.16);
    }

    .record {
        .footer {
            box-sizing: border-box;
            padding: 0 30rpx;
            width: 100%;
            height: 96rpx;
            box-shadow: 0px -4px 20px 0px rgba(0, 0, 0, 0.06);
            background-color: #fff;
            position: fixed;
            bottom: 0;
            z-index: 30;
            padding-bottom: constant(safe-area-inset-bottom); /// 兼容 IOS<11.2/
            padding-bottom: env(safe-area-inset-bottom); /// 兼容 IOS>11.2/

            .bnt {
                width: 160rpx;
                height: 60rpx;
                border-radius: 30rpx;
                border: 1rpx solid #ccc;
                color: #666666;

                &.on {border: 1rpx solid var(--view-theme);
                    margin-left: 16rpx;
                    color: var(--view-theme);
                }
            }
        }

        .nav {
            border-bottom: 1rpx solid #eee;
            color: #999999;
            font-size: 28rpx;
            height: 74rpx;
            padding: 0 30rpx;

            .left {
                color: #333;

                .num {color: var(--view-theme);
                    margin: 0 10rpx;
                }
            }
        }

        .list {
            padding-top: 32rpx;
            padding-bottom: 96rpx;

            .item {
                .title {
                    padding: 0 30rpx;
                    margin-bottom: 34rpx;
                    font-size: 34rpx;
                    font-weight: 600;
                }

                .picList {
                    padding: 0 30rpx 0 12rpx;

                    .picTxt {
                        margin-left: 18rpx;
                        margin-bottom: 48rpx;

                        .pictrue {
                            width: 218rpx;
                            height: 218rpx;
                            border-radius: 10rpx;
                            position: relative;

                            image {
                                width: 100%;
                                height: 100%;
                                border-radius: 10rpx;
                            }

                            .checkbox {
                                position: absolute;
                                right: 10rpx;
                                top: 14rpx;
                            }
                        }

                        .money {
                            font-size: 24rpx;
                            color: var(--view-theme);
                            font-weight: 600;
                            margin-top: 15rpx;

                            .num {
                                font-size: 32rpx;
                                margin-left: 6rpx;
                            }
                        }
                    }
                }
            }
        }
    }
</style>

最初
如果你感觉这篇文章对你有点用的话,麻烦请给咱们的开源我的项目点点 star:http://github.crmeb.net/u/defu 不胜感激!

收费获取源码地址:http://www.crmeb.com

PHP 学习手册:https://doc.crmeb.com

技术交换论坛:https://q.crmeb.com

正文完
 0