2301_76146661 2023-06-06 21:22 采纳率: 80%
浏览 34
已结题

通过添加按钮复制的模块父子组件中的数据相互影响如何避免?

请教,uniapp中(vue2),通过添加按钮复制的模块父子组件中的数据相互影响如何避免,试了几种深拷贝方式都无效。
如图,点击“继续添加按钮”可以复制模块,希望复制模块和原来模块之间数据相互独立,互不影响,而实际上橘色字体部分的数据是相互联动的,不管哪个模块选择数据,另外模块都会变成同样内容,请教这种情况如何处理,代码该怎么写呢?

sortarr是通过云数据库请求下来的三级数组,然后通过页面传值接收过来的

img

<uni-forms class="specs" v-for="(item,index) in sku" :key="index">
    <view class="items">
        <view class="">选择商品(第{{item.title}}组)</view>
        <!-- 当sku的长度大于1,显示删除按钮,否则隐藏 -->
        <view v-if="sku.length > 1" @click="deleteSku(index)">删除</view>
    </view>
    <view class="items">
        <view class="">
            <view class="box-body" @click="toggle('bottom')">
                <view class="" style="color: #FF8247;">{{itemsgrade2name}}->{{itemsname}}</view>
            </view>
            <view>
                <uni-popup class="popuplevel" ref="popup" background-color="#fff" @change="change">

                <view class="popup-content"
                        :class="{ 'popup-height': type === 'left' || type === 'right' }">
                        <text class="popuptitle">请选择服务商品</text>
                        <view class="content1">
                            <view class="left">
                                <scroll-view :scroll-y="true" :scroll-with-animation="true"
                                    :scroll-into-view="clickToId" :style="{'height':windowHeight}">
                                    <view v-for="(v,n) in item.sortarr" :key="n" v-if="v.grade1 === name">
                                        <view v-for="(item,i) in v.grade2" :key="i"
                                            @click="selectitemsgrade2name(''+item.name)">
                                            <view :class="['title',{active:i===currentNum}]" :id="'to'+i"
                                                @click="setId(i)">
                                                        {{item.name}}
                                                    </view>
                                                </view>
                                            </view>
                                        </scroll-view>
                                    </view>
                                    <view class="right">
                                <scroll-view :scroll-into-view="clickId" @scroll="scroll"
                                    :scroll-with-animation="true" :scroll-y="true"
                                    :style="{'height':windowHeight}">
                                    <view v-for="(v,n) in item.sortarr" :key="n" v-if="v.grade1 === name">
                                        <view v-for="(item,i) in v.grade2" :key="i">
                                            <view class="title1,right_title" :id="'po'+i">---{{item.name}}---
                                            </view>
                                            <view v-for="(item,j) in item.grade3" :key="j">
                                                <!-- 打印出来的name部分为undefined,此时需要给参数增加空字符串,如下: -->
                                                <text class="item" v-model="itemsname"
                                                    @click="selectitemsname(''+item.name)">{{item.name}}</text>
                                            </view>
                                        </view>
                                    </view>
                                </scroll-view>
                            </view>
                        </view>
                    </view>
                </uni-popup>
            </view>
        </view>
    </view>
</uni-forms>


逻辑部分

data() {
            return {
                // 三级类目
                itemsname: "请选择商品类别",
                //二级类目
                itemsgrade2name: "-",
                //sku数据
                sku: [{
                    title: 1,
                    sortarr: [],
                    image: []
                }],
                
            }
        },

onLoad: function(option) {
            // 从页面栈中获取参数
            const pages = getCurrentPages();
            const prevPage = pages[pages.length - 2];
            this.sortarr = prevPage.data.sortarr;
            this.sku[0].sortarr = this.sortarr;
methods: {
            // 通过点击事件把选中的值传给itemsgrade2name
            selectitemsgrade2name(name) {
                this.itemsgrade2name = name;
            },
            // 通过点击事件把选中的值传给itemsname
            selectitemsname(name) {
                // console.log(name)
                this.itemsname = name;
                this.$refs.popup[0].close()
                //通过点击选择数据触发弹出层关闭,暂不考虑高度低于屏幕的问题
            },
            //继续添加商品
            addnewsku(e) {
                let number = this.sku[this.sku.length - 1].title;
                number++;
                let sortar=e[0].sortarr;
                const srota=_.cloneDeep(e[0].sortarr)
                // const srota = Object.assign({}, e[0].sortarr);
                    console.log(srota)
                const newsku = {
                    title: number,
                    sortarr:srota,
                    image: []
                };
                console.log(newsku)
                this.sku.push(newsku);
            },
}
  • 写回答

1条回答 默认 最新

  • 白云苍狗い 2023-06-07 08:28
    关注

    你好 你的问题 不在于深不深拷贝 , 我注意到你声明 itemsname,itemsgrade2name这两个变量 用来显示用户选择的商品,但是你这个变量只有一组
    你想啊 你商品一绑定的是这俩 商品2绑定的还是这俩 是不是 就是这商品1=商品2=你定义的变量, 因此你这两个变脸 实际应该也是和sku是一个数组格式 商品1绑定商品1对应变量 商品2绑定商品2对应变量
    可以把这两个变量 在sku每一项中声明 或者单独起一个数组 看你需求

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

问题事件

  • 系统已结题 6月16日
  • 已采纳回答 6月8日
  • 修改了问题 6月6日
  • 修改了问题 6月6日
  • 展开全部

悬赏问题

  • ¥15 校内二手商品转让网站
  • ¥20 高德地图聚合图层MarkerCluster聚合多个点,但是ClusterData只有其中部分数据,原因应该是有经纬度重合的地方点,现在我想让ClusterData显示所有点的信息,如何实现?
  • ¥100 求Web版SPC控制图程序包调式
  • ¥20 指导如何跑通以下两个Github代码
  • ¥15 大家知道这个后备文件怎么删吗,为啥这些文件我只看到一份,没有后备呀
  • ¥15 C++为什么这个代码没报错运行不出来啊
  • ¥15 一道ban了很多东西的pyjail题
  • ¥15 关于#r语言#的问题:如何将生成的四幅图排在一起,且对变量的赋值进行更改,让组合的图漂亮、美观@(相关搜索:森林图)
  • ¥15 C++识别堆叠物体异常
  • ¥15 微软硬件驱动认证账号申请