利用angular.copy取消变量的双向绑定与解析


Posted in Javascript onNovember 25, 2016

首先我们来看看示例代码

<body ng-app="app">
 <div ng-controller="CopyController">
 <div>
 data: <input ng-model="user.data" /><br>
 user.data: {{user.data}} <br>
 user1.data: {{user1.data}} <br>
 <button ng-click="changeData1()">change</button> <br>
 <button ng-click="copy()">copy</button> <br>
 copyData: {{copyUser.data}}
 </div>
 </div>
 <script src="node_modules/angular/angular.min.js"></script>
</body>
<script>
 angular.module('app', [])
 .controller('CopyController', function ($scope) {
 // body...
 $scope.changeData1 = function () {
  // body...
  scope.user1=scope.user1=
scope.user;
  $scope.user1.data = 'is changed';
 }
 $scope.copy = function () {
  // body...
  scope.copyUser=angular.copy(scope.copyUser=angular.copy(
scope.user);
 }
 });
</script>

利用angular.copy取消变量的双向绑定与解析

从上面的演示可以看到,当点击copy按钮时,copyData的值就变成了”this is old data”,成功将user的值复制到copyUser.

当点击change按钮后,user1和user的值都变成了'is changed',而copyUser的值却没有发生改变。这时候在input输入框改变值,user和user1的值都会跟着改变,说明了这二者实际上是同一个变量引用。而copyUser没有发生变化。

angular.copy 能取消双向绑定的原理

这跟JavaScript中对象是引用类型有关。

JavaScript中的值类型

在JavaScript中,值分为原始值和引用值两种类型。

     原始值:存储在栈(Stack)中的简单数据字段,也就是说,它们的值是直接存储在变量访问的位置;

     引用值:存储在堆(heap)中,也就是说,存储在变量处的值是一个指针,指向存储对象的内存处。

如下图所示:

利用angular.copy取消变量的双向绑定与解析

在JavaScript中的对象便是引用值,也就是说对象是通过引用传递值的。

所以在上述的代码中:

对象$scope.user$scope.user1的值都是指向了同一个引用。对于Angular来说,监听变量变化是在监听其对象所引用的地址,所以当对象的引用值发生了变化,所有指向它的对象都会跟着发生变化。

所以在Angular中,直接通过对象的赋值是无法解除双向绑定的。所以要想解除双向绑定的办法就是新创建个对象,然后将原有的对象的值赋值给新对象。这不就是JavaScript中的深拷贝嘛。

对的,angular.copy就是Angular提供的 deep copy 的方法。所以通过angular.copy复制出来的对象,既能和原有的对象值保持一致,又不与旧对象指向同一个引用,从而实现了解除对象变量的双向绑定。

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家学习或者使用Angular.js能有所帮助,如果有疑问大家可以留言交流。

Javascript 相关文章推荐
重定向实现代码
Nov 20 Javascript
ASP.NET jQuery 实例4(复制TextBox的文本到本地剪贴板上)
Jan 13 Javascript
js的alert样式如何更改如背景颜色
Jan 22 Javascript
强大Vue.js组件浅析
Sep 12 Javascript
基于JavaScript实现瀑布流效果
Mar 29 Javascript
20行js代码实现的贪吃蛇小游戏
Jun 20 Javascript
详解react-redux插件入门
Apr 19 Javascript
详解小程序输入框闪烁及重影BUG解决方案
Aug 31 Javascript
9102了,你还不会移动端真机调试吗
Mar 25 Javascript
node.js中process进程的概念和child_process子进程模块的使用方法示例
Feb 11 Javascript
详解 javascript对象创建模式
Oct 30 Javascript
基于javascript实现移动端轮播图效果
Dec 21 Javascript
JS冒泡事件与事件捕获实例详解
Nov 25 #Javascript
js事件源window.event.srcElement兼容性写法(详解)
Nov 25 #Javascript
使用JS读取XML文件的方法
Nov 25 #Javascript
JS比较两个数值的大小实例
Nov 25 #Javascript
使用JavaScript解决网页图片拉伸问题(推荐)
Nov 25 #Javascript
js移动焦点到最后位置的简单方法
Nov 25 #Javascript
详解JS几种变量交换方式以及性能分析对比
Nov 25 #Javascript
You might like
模拟xcopy的函数
2006/10/09 PHP
PHP memcache扩展的三种安装方法
2009/04/26 PHP
PHP iconv 解决utf-8和gb2312编码转换问题
2010/04/12 PHP
jQuery滚动加载图片实现原理
2015/12/14 Javascript
AngularJS  自定义指令详解及实例代码
2016/09/14 Javascript
Bootstrap学习笔记之环境配置(1)
2016/12/07 Javascript
bootstrap下拉菜单使用方法解析
2017/01/13 Javascript
详解Vue CLI 3.0脚手架如何mock数据
2018/11/23 Javascript
微信小程序实现的图片保存功能示例
2019/04/24 Javascript
vue 进阶之实现父子组件间的传值
2019/04/26 Javascript
微信小程序 扭蛋抽奖机css3动画实现详解
2019/07/19 Javascript
浅谈layui数据表格判断问题(加入表单元素),设置单元格样式
2019/10/26 Javascript
vue实现轮播图帧率播放
2021/01/26 Vue.js
[03:24]CDEC.Y赛前采访 努力备战2016国际邀请赛中国区预选赛
2016/06/25 DOTA
[36:54]Mineski vs Winstrike 2018国际邀请赛小组赛BO2 第一场 8.16
2018/08/17 DOTA
Python中非常实用的一些功能和函数分享
2015/02/14 Python
python采用django框架实现支付宝即时到帐接口
2016/05/17 Python
代码讲解Python对Windows服务进行监控
2018/02/11 Python
对python 多个分隔符split 的实例详解
2018/12/20 Python
python的等深分箱实例
2019/11/22 Python
pyenv虚拟环境管理python多版本和软件库的方法
2019/12/26 Python
pytorch实现线性拟合方式
2020/01/15 Python
使用CSS变量实现炫酷惊人的悬浮效果
2019/04/26 HTML / CSS
一款利用html5和css3动画排列人物头像的实例演示
2014/12/05 HTML / CSS
使用纯HTML5编写一款网页上的时钟的代码分享
2015/11/16 HTML / CSS
美国办公用品购物网站:Quill.com
2016/09/01 全球购物
诺心蛋糕官网:LE CAKE
2018/08/25 全球购物
架构师岗位职责
2013/11/18 职场文书
精彩自我鉴定
2014/01/16 职场文书
致垒球运动员加油稿
2014/02/16 职场文书
劳动工资科岗位职责范本
2014/03/02 职场文书
综合素质评价自我评价
2015/03/06 职场文书
自主招生推荐信格式模板
2015/03/24 职场文书
小学生读书笔记范文
2015/06/30 职场文书
学术研讨会主持词
2015/07/04 职场文书
建议书的格式及范文
2015/09/14 职场文书