zoukankan      html  css  js  c++  java
  • 转:说说angularjs中的$parse和$eval

    说说AngularJS中的$parse和$eval

    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  
  • 相关阅读:
    面试准备专题——JVM,类编译,类加载,内存错误
    面试准备-基础知识总结
    J2EE异常问题总结
    Java工具类使用注意事项
    高性能大型网站性能优化基础
    Spring Boot 2 (三):Spring Boot 开源软件都有哪些?
    Spring Boot 2(一):【重磅】Spring Boot 2.0权威发布
    Spring Boot 2 (二):Spring Boot 2 尝鲜-动态 Banner
    MFC对话框使用CPrintDialog实现打印,指定打印机、后台打印
    stm32实现iap远程固件更新
  • 原文地址:https://www.cnblogs.com/stephenykk/p/3937096.html
Copyright © 2011-2022 走看看