Angularjs手动解析表达式($parse)

时间:2021-05-28

下面一段代码给大家介绍了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),希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!

声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。

相关文章