国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

Angularjs手動解析表達式($parse)

2019-11-20 08:46:26
字體:
來源:轉載
供稿:網友

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

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 龙门县| 新乡县| 湖州市| 宁波市| 长寿区| 德令哈市| 尖扎县| 商河县| 正镶白旗| 三台县| 隆回县| 台东市| 宁德市| 略阳县| 抚顺市| 凤翔县| 建水县| 上蔡县| 昌黎县| 巨野县| 靖边县| 双江| 汨罗市| 潼南县| 临汾市| 胶南市| 西乌珠穆沁旗| 夏邑县| 金堂县| 施甸县| 宁南县| 汝南县| 长阳| 田阳县| 右玉县| 兖州市| 乌苏市| 长兴县| 杭锦旗| 芷江| 临夏市|