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

首頁 > 編程 > JavaScript > 正文

AngularJs expression詳解及簡單示例

2019-11-20 09:06:24
字體:
來源:轉載
供稿:網友

         表達式(Expressions)是類Javascript的代碼片段,通常放置在綁定區域中(如{{expression}})。表達式通過$parse服務(http://code.angularjs.org/1.0.2/docs/api/ng.$parse)解析執行。

  例如,以下是angular中有效的表達式:

  1. 1+2
  2. 3*10 | currency
  3. user.name

一、Angular表達式 vs. Js 表達式

  這很容易讓人將angular視圖表達式聯想為javascript表達式,但這并不完全正確,因為angular不是通過javascript的eval()對表達式進行求值。你可以將angular表達式想象為帶有以下差異的javascript表達式:

  1. 屬性求值:所有屬性的求值是對于scope的,而javascript是對于window對象的。
  2. 寬容(forgiving):表達式求值,對于undefined和null,angular是寬容的,但Javascript會產生NullPointerExceptions(-_-!!!!怎么我沒見過)。
  3. 沒有流程控制語句:在angular表達式里,我們不能做以下任何的事:條件分支、循環、拋出異常。
  4. 過濾器(filters):我們可以就將表達式的結果傳入過濾器鏈(filter chains)。例如將日期對象轉換為本地指定的人類可讀的格式。

  另一方面,如果我們想(在angular表達式中)執行任意的Javascript代碼,我們可以將那些代碼寫到Controller的一個方法中并調用它。如果我們想在javascript中eval()一個angular表達式,可以使用$eval()方法。

<!DOCTYPE HTML><html lang="zh-cn" ng-app="ExpressionTest"><head>  <meta charset="UTF-8">  <title>expression-e1</title>  <style type="text/css">    .ng-cloak {      display: none;    }  </style></head><body ng-controller="MyCtrl">1 + 2 = {{1+2}}<br/>Expression:<input type="text" ng-model="expr"/><button ng-click="addExp(expr)">Evaluate</button><ul>  <li ng-repeat="expr in exprs">    [<a ng-click="removeExp($index)" href="">X</a>]    <tt>{{expr}}</tt>=><span ng-bind="$parent.$eval(expr)"></span>  </li></ul><script src="../angular-1.0.1.js" type="text/javascript"></script><script type="text/javascript">  var app = angular.module("ExpressionTest", []);  app.controller("MyCtrl", function ($scope) {    var exprs = $scope.exprs = [];    $scope.expr = "3*10|currency";    $scope.addExp = function(expr) {      exprs.push(expr);    };    $scope.removeExp = function (index) {      exprs.splice(index, 1);    };  });</script></body></html>

二、屬性求值(Property Evaluation)

  angular的表達式解析環境的上下文是scope,而javascript則是window(應該是指嚴格模式evel的時候),angular需要通過$window訪問global window對象。例如,如果我們需要在表達式中調用定義在window對象上的alert(),我們需要使用$window.alert()。這樣做的用意是避免意外訪問了公共屬性(global state)(一個同源的小BUG?a common source of subtle bugs)。

<!DOCTYPE HTML><html lang="zh-cn" ng-app="PropertyEvaluation"><head>  <meta charset="UTF-8">  <title>PropertyEvaluation</title>  <style type="text/css">    .ng-cloak {      display: none;    }  </style></head><body><div ng-controller="MyCtrl">  Name: <input ng-model="name" type="text"/>  <button ng-click="greet()">Greet</button></div><script src="../angular-1.0.1.js" type="text/javascript"></script><script type="text/javascript">  var app = angular.module("PropertyEvaluation", []);  app.controller("MyCtrl", function ($scope,$window) {    $scope.name = "Kitty";    $scope.greet = function() {      $window.alert("Hello " + $scope.name);    };  });</script></body></html>

三、Forgiving(寬容,容錯?)

  表達式求值對undefined和null是寬容的。在javascript中,當a不是object的時候,對a.b.c求值,那么將會拋出一個異常。有時候這對于通用語言來說是合理的,而表達式求值主要用于數據綁定,一般形式如下:

{{a.b.c}}

   如果a不存在,沒有任何顯示似乎比拋出異常更加合理(除非我們等待服務端響應,不一會兒就會被定義)。如果表達式求值時不夠寬容,那么我們如此混亂地寫綁定代碼:

{{((a||{}).b||{}).c}}    //這……

   相似地,引用一個函數a.b.c()時,如果它是undefined或者null,那么簡單地返回undefined。

四、沒有控制流程語句(No Control Flow Statements)

  我們不可以在表達式中寫流程控制語句。背后的原因是,angular的核心體系是應用的邏輯應當在controller(的scope)里面,而不是在view里面。如果我們需要在視圖表達式中加入條件分支、循環或者拋出異常的話,可以委托javascript方法去代替(可以調用scope中的方法)。

五、過濾器(Filters)

  當我們向用戶呈現數據時,我們可能需要將數據從原始格式轉換為友好(可讀性強)的格式。例如,我們有一個數據對象需要在顯示給用戶之前根據地域進行格式化。我們可以將表達式傳遞給一連串的過濾器,如:

name | uppercase

   這表達式求值器可簡單地傳遞name的值到uppercase過濾器中。

  鏈式過濾器使用這種語法:

value | filter1 | filter2

   我們也可以傳送用冒號分割的參數到filter中,例如,以兩位小數的格式顯示123:

123 | number:2 

六、前綴”$”

  我們可能會感到奇怪,前綴”$”的意義是什么?它是angular為了使本身的API名稱能夠區別于其他的API而使用的一個簡單的前綴(防止沖突)。如果angular不使用$,那么對a.length()求值將返回undefined。因為a和angular本身都沒有定義這個屬性。

  考慮到angular將來的版本可能會選擇增加length這個方法,這將令這個表達式的行為發生改變。更糟糕的是,我們開發者可能會創建一個length屬性,那么將與angular發生沖突。這個問題存在因為angular通過增加方法擴展了當前存在的對象。通過加入前綴”$”,angular保留了特定的namespace,所以angular的開發者與使用angular的開發者都可以和諧共處。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 罗山县| 新昌县| 兴文县| 汝南县| 锡林郭勒盟| 建阳市| 南投县| 湖州市| 甘泉县| 黄龙县| 梧州市| 天门市| 伊川县| 平谷区| 晋江市| 广元市| 张家川| 含山县| 拉萨市| 大理市| 临洮县| 延长县| 沈丘县| 延庆县| 花莲县| 柳江县| 安阳市| 昌平区| 青岛市| 浦江县| 廉江市| 从化市| 永康市| 三门峡市| 泽普县| 伊金霍洛旗| 永平县| 灵山县| 泰安市| 垣曲县| 吉隆县|