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