Vue数据改变视图没变? :bind传递值和对象的区别?

  首先这是一片记录性的文章,只能给观看的人提供一种问题的解决思路,个人目前并没有兴趣或者是时间去翻看Vue的源码,所以不喜勿喷~
  #问题背景:
由于自己项目的需求需要用到VueDraggable这个插件,用来实现拖拽改变数组数据的功能,看起来和测试都没什么问题。但是在自己的项目上实验的时候,发现鼠标拖动完,事件确实触发了,测试的时候数组内容也发生改变了,为啥页面上的东西看起来就是没有变化呢??
  #解决:
  在我反复确认不是参数或者是设定出问题之后,把矛头指向了:bind上面,我发现别人的demo里面用的都是最简单的标签比如p,div之类的
而我的是自己封装的一个组件,同时把数组中的对象bind到组件之中。然后就测试,在我自己的封装的组件中,只传对象的一个值,不传整个对象,发现视图竟然真的变化了。
所以我第一反应是,把整个对象的所有属性拆分开传递过去。但是怎么想怎么不合适,就单从封装和可维护性上而言。。然后哈哈哈哈哈哈哈哈就是我自己佩服自己的无敌的解决办法,传过去对象的同时把一个一定会有的属性值也传递过去,比如key或者name什么,就强制导致视图跟着数组发生变化啦哈哈哈哈,半个上午解决了个虽然本身不应该存在但是还是不是很小并且比较重要的问题,嗯,高兴!
  #目前只能猜测
  :bind 一个属性和一整个对象在这里好像是有差距的,如果我只传递一个对象,传过去的应该只是一个引用值,尽管原对象数组顺序发生改变了,但是对象的地址或者是某种引用关系并没有发生改变。而当我传递一个属性值过去的时候,传过去的值就是值,数组变了,原索引的值就不是那个值了,所以视图发生了刷新!

###求大佬点明指正!!
 

你可能感兴趣的:(Java,学习,三月)