利用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 相关文章推荐
jquery常用技巧及常用方法列表集合
Apr 06 Javascript
javascript中将Object转换为String函数代码 (json str)
Apr 29 Javascript
使用GruntJS构建Web程序之构建篇
Jun 04 Javascript
JavaScript中继承用法实例分析
May 16 Javascript
JS修改地址栏参数实例代码
Jun 14 Javascript
jQuery实现对象转为url参数的方法
Jan 11 Javascript
Node.js如何对SQLite的async/await封装详解
Feb 14 Javascript
vue父组件触发事件改变子组件的值的方法实例详解
May 07 Javascript
vuex 动态注册方法 registerModule的实现
Jul 03 Javascript
vue如何限制只能输入正负数及小数
Jul 04 Javascript
vue+vant使用图片预览功能ImagePreview的问题解决
Apr 10 Javascript
详解JSON.stringify()的5个秘密特性
May 26 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
Session服务器配置指南与使用经验的深入解析
2013/06/17 PHP
Laravel5.1自定义500错误页面示例
2016/10/09 PHP
解决laravel 出现ajax请求419(unknown status)的问题
2019/09/03 PHP
Thinkphp5.0框架视图view的循环标签用法示例
2019/10/12 PHP
nodejs开发微博实例
2015/03/25 NodeJs
javascript使用avalon绑定实现checkbox全选
2015/05/06 Javascript
使用nodejs开发cli项目实例
2015/06/03 NodeJs
jQuery插件passwordStrength密码强度指标详解
2016/06/24 Javascript
jQuery插件HighCharts绘制的基本折线图效果示例【附demo源码下载】
2017/03/07 Javascript
BootStrap Table 后台数据绑定、特殊列处理、排序功能
2017/05/27 Javascript
关于定制FileField中的上传文件名称问题
2017/08/22 Javascript
vue引入ueditor及node后台配置详解
2018/01/03 Javascript
详解webpack 热更新优化
2018/09/13 Javascript
JS实现可切换图片的幻灯切换效果示例
2019/05/24 Javascript
JavaScript实现拖动对话框效果的实现代码
2020/10/12 Javascript
vue3使用vue-count-to组件的实现
2020/12/25 Vue.js
使用python 获取进程pid号的方法
2014/03/10 Python
Python学习笔记(一)(基础入门之环境搭建)
2014/06/05 Python
python实现简单的计时器功能函数
2015/03/14 Python
Ubuntu 16.04 LTS中源码安装Python 3.6.0的方法教程
2016/12/27 Python
Python实现excel转sqlite的方法
2017/07/17 Python
python 3.7.0 安装配置方法图文教程
2018/08/27 Python
python进行文件对比的方法
2018/12/24 Python
django 中QuerySet特性功能详解
2019/07/25 Python
在Python中预先初始化列表内容和长度的实现
2019/11/28 Python
使用python爬取抖音app视频的实例代码
2020/12/01 Python
基于 Python 实践感知器分类算法
2021/01/07 Python
悦木之源美国官网:Origins美国
2016/08/01 全球购物
关于梦想的演讲稿
2014/05/05 职场文书
应届大专生求职信
2014/06/26 职场文书
2014年党建工作汇报材料
2014/10/27 职场文书
2014年大学团支部工作总结
2014/12/02 职场文书
小学国庆节活动总结
2015/03/23 职场文书
写给老师的保证书
2015/05/09 职场文书
创业计划书之餐饮
2019/09/02 职场文书
有关信念的名言语录集锦
2019/12/06 职场文书