收藏
回答

对象类型的变量A,将A赋值给变量B,将A的某属性赋值给变量C,更改变量C的值,B也会自动跟着被更改?

有如下代码:

    var id = that.data.wid

    var tfl = that.data.tfl   

    var tpnew = that.data.tfl.tp

    var qa = that.data.queryResult

    var zts = qa[id].zts  

    var tpold = '' 

    if(zts&&zts.length>0){

      zts.forEach(function(item){

        if(item.zt==that.data.title&&item.hasOwnProperty('tp')){

          tpold=item.tp

        }

      })

    }

    if(tpold){

      if(tpnew.length>0){

        tpold.forEach(function(item){

          var okg = 0 

          tpnew.forEach(function(it,index){

            if(item==it){

              console.log('tfl:',tfl)

              console.log('tpnew:',tpnew)

              tpnew.splice(index,1) ///////////修改tpnew的值

              console.log('tpnew:',tpnew)

              okg=1

              console.log('tfl2:',tfl) ////////这时候显示tfl的值也被改了

            }

            if(index==tpnew.length-1&&okg==0){

              console.log('id:',that.data.swid)

            }

          })

        })

      }

    }

在运行过程中,更改了tpnewr的值后,tfl的值也随之改变,请问我的代码出错在哪?

回答关注问题邀请回答
收藏

3 个回答

  • 拾柒
    拾柒
    2022-03-11

    去了解下对象深拷贝和浅拷贝

    2022-03-11
    有用 1
    回复 1
    • 总得通
      总得通
      发表于移动端
      2022-03-11
      谢谢您,己解决了。
      2022-03-11
      回复
  • 老张
    老张
    2022-03-10

    js基本知识了。

    一般自己写几行代码演示一下就明白了。

    2022-03-10
    有用 1
    回复 3
    • 总得通
      总得通
      2022-03-10
      师傅,可否明示一二?我刚学的,弄了两天都不明白。
      2022-03-10
      回复
    • 老张
      老张
      2022-03-10回复总得通
      类似这样的代码,你写几句就明白了。对象变量是指针引用,或者你百度一下“JS对象深拷贝”。
      2022-03-10
      1
      回复
    • 总得通
      总得通
      发表于移动端
      2022-03-10回复老张
      谢谢!
      2022-03-10
      回复
  • 总得通
    总得通
    2022-03-10

    2022-03-10
    有用
    回复
登录 后发表内容