Angularjs手動解析運算式($parse)_javascript技巧

來源:互聯網
上載者:User

下面一段代碼給大家介紹了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),希望對大家有所協助,如果大家有任何疑問請給我留言,小編會及時回複大家的。在此也非常感謝大家對雲棲社區網站的支援!

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.