时间:2021-09-04 09:47:40 | 栏目:JavaScript代码 | 点击:次
下面一段代码给大家介绍了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) { // 用该表达式设置parseFun var parseFun = $parse(newVal); // 获取经过解析后表达式的值$scope.parsedValue = parseFun(scope); }}); });