虚位以待(AD)
虚位以待(AD)
首页 > 网页特效 > JavaScript > Angularjs手动解析表达式($parse)

Angularjs手动解析表达式($parse)
类别:JavaScript   作者:码皇   来源:互联网   点击:

这篇文章主要介绍了Angularjs手动解析表达式($parse)的相关资料,非常不错,具有参考借鉴价值,需要的朋友可以参考下

下面一段代码给大家介绍了angularjs手动解析表达式($parse),具体代码如下所示:

    <!DOCTYPE html><html lang="zh-CN" ng-app="app"><head><meta charset="utf-8"><title>手动解析表达式($parse)</title><link rel="stylesheet" href="../bootstrap.min.js"></head><body ng-controller="myController"><div ng-controller="myController"><input type="text" ng-model="expr" placeholder="enter an expression"><h2>{
    {
    parsedValue }
    }
    </h2></div><script src="../angular.min.js"></script><script>angular.module('app', []).controller('myController', function($scope, $parse) {
    $scope.$watch('expr', function(newVal, oldVal, s) {
    if(newVal !== oldVal) {
    var parseFun = $parse(newVal);
    $scope.parsedValue = parseFun(s);
    // 使用链式调用的方式 你也可以这样写 // $scope.parsedValue = $parse(newVal)(s);
    }
    }
    )}
    )</script></body></html>

补充:解析AngularJS表达式

尽管AngularJS会在运行$digest循环的过程中自动解析表达式,但有时手动解析表达式也是非常有用的。AngularJS通过$parse这个内部服务来进行表达式的运算,这个服务能够访问当前所处的作用域。这个过程允许我们访问定义在$scope上的原始JavaScript数据和函数。将$parse服务注入到控制器中,然后调用它就可以实现手动解析表达式。举例来说,如果页面上有一个输入框绑定到了expr变量上,如下所示:

    <div ng-controller="MyController"><input ng-model="expr"type="text"placeholder="Enter an expression" /><h2>{
    {
    parseValue }
    }
    </h2></div>

我们可以在MyController中给expr这个表达式设置一个$watch并解析它:

    angular.module("myApp", []).controller('MyController',function($scope,$parse) {
    $scope.$watch('expr', function(newVal, oldVal, scope) {
    if (newVal !== oldVal) {
    // 用该表达式设置parseFunvar parseFun = $parse(newVal);
    // 获取经过解析后表达式的值$scope.parsedValue = parseFun(scope);
    }
    }
    );
    }
    );

以上所述是小编给大家介绍的Angularjs手动解析表达式($parse),希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!

相关热词搜索: angularjs 解析表达式 angularjs parse