博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
浅谈AngularJS中的$parse和$eval
阅读量:6241 次
发布时间:2019-06-22

本文共 1146 字,大约阅读时间需要 3 分钟。

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属性也是一个函数,它可以用来在给定的上下文中改变这个表达式的值。

下面是一段简单的代码:

testing
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

转载于:https://www.cnblogs.com/gongshunkai/p/7062246.html

你可能感兴趣的文章
判断图中两个结点间是否有特定长度的路径
查看>>
Yii2.0 rules验证规则集合的详细介绍
查看>>
世界最好编程语言之父来华,约吗?
查看>>
RSA和MD5加密
查看>>
Swift 中的利刃,函数和闭包
查看>>
iOS开发之顶部状态栏statusBar颜色变化小结
查看>>
sql高级用法
查看>>
mysql安装
查看>>
Web前端开发规范(二)
查看>>
uva 621 - Secret Research
查看>>
MAC快捷键
查看>>
动态代理模式
查看>>
mysql数据操作语句
查看>>
jinja2模版生成页面时会产生大量空行和空格,如何移除?
查看>>
sublime的代码格式化快捷键
查看>>
Mybatis - Sql标签详解
查看>>
Xftp 如何显示隐藏文件?
查看>>
回归的线性模型---线性基函数模型
查看>>
强上阿里云之安装memcached
查看>>
(已解决)struts2 date 标签 问题 ,貌似是个BUG 大家鉴定下
查看>>