说说AngularJS中的$parse和$eval的用法


Posted in Javascript onSeptember 14, 2017

AngularJS的初学者常常会对$parse和$eval两个内建服务感到有些困惑,今天我们就来说说AngularJS中的$parse和$eval。

总的来说,$parse和$eval都是作用于AngularJS的表达式。

什么是表达式?

AngularJS中的表达式就是一些类似于JavaScript代码的代码片段(但是它们和JavaScript代码有不尽相同)。表达式通常被用来防止在绑定中,例如{{expression}}。下面是一个例子:

1 + 2 = {{ 1 + 2 }}

或者:

My name is {{ user.name }} 

$parse服务

$parse服务可以讲一个表达式转换为一个函数。这个函数可以被调用,其中的参数是一个上下文对象,通常来说是作用域。

另外,通过$parse的表达式返回的这个函数有一个assign属性。这个assign属性也是一个函数,它可以用来在给定的上下文中改变这个表达式的值。

下面是一段简单的代码:

<div my-attr="obj.name" my-directive>testing</div>
app.directive('myDirective',function($log,$parse){
  return function(scope,elem,attrs){
    //解析"my-attr属性值到一个函数中"
    var model = $parse(attrs.myAttr);
    //model现在是一个函数,可以调用它来获取表达式的值
    //下面这行代码将会输出作用域中obj.name的值 
    $log.log(model(scope));

    elem.bind('click',function(){
    //'model.assign'也是一个函数,它用来更新表达式的值 
    model.assign(scope,'New name');
    scope.$apply();
    })
  }
});

上面的例子可以充分体现我们为什么需要$parse服务。如果属性值是name,那么我们完全可以不用$parse,只用scope[attrs.myAttr]即可。但是在上面的例子中,方括号并不管用。

$eval服务

$eval是一个作用域scope中的方法,它将会在当前作用域中执行一个表达式并返回结果:

scope.a = 1;
scope.b = 2;

scope.$eval('a+b'); // 3

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
农历与西历对照
Sep 06 Javascript
用JS写的一个TableView控件代码
Jan 23 Javascript
DOM基础教程之使用DOM + Css
Jan 20 Javascript
JavaScript原生对象之Date对象的属性和方法详解
Mar 13 Javascript
浅谈JS继承_借用构造函数 &amp; 组合式继承
Aug 16 Javascript
jQuery的Cookie封装,与PHP交互的简单实现
Oct 05 Javascript
使用sessionStorage解决vuex在页面刷新后数据被清除的问题
Apr 13 Javascript
node.js中express模块创建服务器和http模块客户端发请求
Mar 06 Javascript
vue轻量级框架无法获取到vue对象解决方法
May 12 Javascript
vue遍历生成的输入框 绑定及修改值示例
Oct 30 Javascript
解决element-ui的下拉框有值却无法选中的情况
Nov 07 Javascript
微信小程序中使用vant框架的具体步骤
Feb 18 Javascript
用JS编写一个函数,返回数组中重复出现过的元素(实例)
Sep 14 #Javascript
日期时间范围选择插件:daterangepicker使用总结(必看篇)
Sep 14 #Javascript
详解React Native顶|底部导航使用小技巧
Sep 14 #Javascript
Angularjs 1.3 中的$parse实例代码
Sep 14 #Javascript
浅谈JavaScript中的属性:如何遍历属性
Sep 14 #Javascript
基于node.js express mvc轻量级框架实践
Sep 14 #Javascript
gulp教程_从入门到项目中快速上手使用方法
Sep 14 #Javascript
You might like
40个迹象表明你还是PHP菜鸟
2008/09/29 PHP
php根据分类合并数组的方法实例详解
2013/11/06 PHP
Laravel 手动开关 Eloquent 修改器的操作方法
2019/12/30 PHP
php模拟实现斗地主发牌
2020/04/22 PHP
由浅到深了解JavaScript类
2006/09/08 Javascript
javascript优先加载笔记代码
2008/09/30 Javascript
jQuery统计上传文件大小的方法
2015/01/24 Javascript
Angularjs处理页面闪烁的解决方法
2017/03/09 Javascript
Vue2.0 slot分发内容与props验证的方法
2017/12/12 Javascript
在vue组件中使用axios的方法
2018/03/16 Javascript
JS使用tween.js动画库实现轮播图并且有切换功能
2018/07/17 Javascript
从零开始在NPM上发布一个Vue组件的方法步骤
2018/12/20 Javascript
JavaScript如何实现元素全排列实例代码
2019/05/14 Javascript
一次微信小程序内地图的使用实战记录
2019/09/09 Javascript
JavaScript实现京东放大镜效果
2019/12/03 Javascript
vue组件开发之tab切换组件使用详解
2020/08/21 Javascript
[02:51]2014DOTA2 TI小组赛总结中国军团全部进军钥匙球馆
2014/07/15 DOTA
Python读取ini文件、操作mysql、发送邮件实例
2015/01/01 Python
python判断给定的字符串是否是有效日期的方法
2015/05/13 Python
python 回调函数和回调方法的实现分析
2016/03/23 Python
Python numpy 提取矩阵的某一行或某一列的实例
2018/04/03 Python
python中的数组赋值与拷贝的区别详解
2019/11/26 Python
使用Pandas的Series方法绘制图像教程
2019/12/04 Python
html5 Canvas画图教程(1)—画图的基本常识
2013/01/09 HTML / CSS
找到不普通的东西:Bonanza
2016/10/20 全球购物
在线购买廉价折扣书籍和小说:BookOutlet.com
2018/02/19 全球购物
荷兰美妆护肤品海淘网站:Beautinow(中文)
2020/11/22 全球购物
商务日语专业毕业生求职信
2013/10/26 职场文书
体育教育个人自荐信范文
2013/12/01 职场文书
住宅使用说明书
2014/05/09 职场文书
2015年元宵节活动总结
2015/02/06 职场文书
员工辞职信范文
2015/03/02 职场文书
解约证明模板
2015/06/19 职场文书
九九重阳节致辞
2015/07/31 职场文书
关于Javascript闭包与应用的详解
2021/04/22 Javascript
Python实现聚类K-means算法详解
2022/07/15 Python