下面一段代碼給大家介紹了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); }}); });
以上所述是小編給大家介紹的Angularjs手動解析表達式($parse),希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對網站的支持!