GVKun编程网logo

详解JavaScript的AngularJS框架中的表达式与指令(angular js表达式)

29

如果您想了解详解JavaScript的AngularJS框架中的表达式与指令和angularjs表达式的知识,那么本篇文章将是您的不二之选。我们将深入剖析详解JavaScript的AngularJS框

如果您想了解详解JavaScript的AngularJS框架中的表达式与指令angular js表达式的知识,那么本篇文章将是您的不二之选。我们将深入剖析详解JavaScript的AngularJS框架中的表达式与指令的各个方面,并为您解答angular js表达式的疑在这篇文章中,我们将为您介绍详解JavaScript的AngularJS框架中的表达式与指令的相关知识,同时也会详细的解释angular js表达式的运用方法,并给出实际的案例分析,希望能帮助到您!

本文目录一览:

详解JavaScript的AngularJS框架中的表达式与指令(angular js表达式)

详解JavaScript的AngularJS框架中的表达式与指令(angular js表达式)

“指令属性”就是绑定在DOM元素上的函数,它可以调用方法、定义行为、绑定controller及$scope对象、操作DOM,等等等等。

当浏览器启动、开始解析HTML(像平时一样)时,DOM元素上的指令属性就会跟其他属性一样被解析。

当一个Angular.js应用启动,Angular编译器就会遍历DOM树(从有ng-app指令属性的那个DOM元素开始,如我们在本系列第一篇里所提过的),解析HTML,寻找这些指令属性函数。

当在一个DOM元素上找到一个或多个这样的指令属性函数,它们就会被收集起来、排序,然后按照优先级顺序被执行。

每个指令属性都有自己的优先级,在我们关于指令属性的专题文章里(http://www.ng-newsletter.com/posts/directives.html),你可以找到更深入的信息。

Angular.js应用的动态性和响应能力,都要归功于指令属性。之前我们已经看过一些指令属性的用例:

ng-model

rush:js;"> Your name: {{ name }}

试试看

ng-model指令属性(我们在之前的章节使用过它),被用来将DOM文本输入框的值,跟controller里的$scope model绑定起来。具体的实现过程,是在这个值上绑定了一个$watch函数(类似JavaScript里的事件监听函数)。

$watch函数(在使用时)运行在Angular.js的事件循环(即$digest循环)里,让Angular.js能够对DOM进行相应的更新。请关注我们关于$digest循环的高级文章!

在Angular.js应用的开发中,我们用指令属性来将行为绑定到DOM上。指令属性的使用,是一个 应用能否拥有动态性、响应能力的关键。Angular.js提供了很多缺省的指令属性,现在让我们来看看其中几个,以及如何使用它们。

几个常见的指令属性:

{{ 表达式 }}

这个双大括号指令属性,使用$watch()函数,给括号内的表达式注册了一个监听器。正是这个$watch函数,让Angular.js能够实时自动更新view。

那么,到底什么算是个表达式? 要想理解指令属性的运作,我们必须先理解表达式,所以这里我们就绕个路,看看本系列的第五部分——表达式。在之前的例子里我们已经见过表达式,例如 {{ person.name }} 和 {{ clock }}。

rush:js;"> {{ 8 + 1 }}9 {{ person }}{"name":"Ari Lerner"} {{ 10 * 3.3 | currency }}$33.00

最后的例子里 (10 * 3.3 | currency) 用了一个过滤器。本系列之后的部分,会深入介绍过滤器。

表达式粗略来看有点像 eval(javascript) 的结果。它们会经过Angular.js的处理,从而拥有以下重要而独特的性质:

所有表达式都在scope这个context里被执行,因此可以使用所有本地 $scope 中的变量。 如果一个表达式的执行导致类型错误或引用错误,这些错误将不会被抛出。 表达式里不允许任何控制函数流程的功能(如if/else等条件语句) 表达式可接受一个或多个串联起来的过滤器。 试试看

试试输入“person“,“clock“或其他数学算式如2+4。你甚至可以操作scope,例如,试试输入person.name = ”Ari”; person.age = 28; person 或 clock

表达式都运行在调用它们的scope里,所以一个表达式可访问并操作其scope上的一切。由此,你可以使用表达式遍历其scope的属性(我们在ng-repeat中会看到这一应用)、调用scope里的函数,或者对scope中的变量进行数学运算。

现在,让我们回到指令属性…

ng-init

ng-init指令属性是一个在启动时运行的函数(在程序进入运行阶段之前)。它让我们能够在程序运行前设定初始变量的值:

rush:js;"> Hello,{{ name }}

试试看

rush:plain;"> Hello,Ari Lerner

ng-click

ng-click指令属性给DOM元素注册了一个点击事件的监听器。当此DOM元素上有点击事件发生(即当此button或link被点击时),Angular.js就会执行表达式的内容,并相应地更新view。

rush:js;">

试试看

我们也可以用ng-click 来调用在controller里写好并绑定在$scope上的函数,例如:

rush:js;">

controller 里的函数:

rush:js;"> app.controller('MyController',function($scope) { $scope.sayHello = function() { alert("hello!"); } });

试试看

ng-show / ng-hide

ng-show和ng-hide指令,根据赋予它们的表达式的值的真假性(truthy),来显示和隐藏它们所属的那一部分DOM。

我们在这里不会深入,但你应该熟悉JavaScript中变量值的“truthy”和“falsy”概念。

rush:js;">

ng-repeat

ng-repeat指令遍历一个数据集合中的每个数据元素,加载HTML模版把数据渲染出来。被重复使用的模版元素,就是我们绑定了这个指令属性的DOM元素。每一个使用模版渲染的DOM元素都有自己的scope。

在更多的解释之前,我们先看一个例子。假设我们的controller里有这样一个数据元素的数组:

rush:js;"> $scope.roommates = [ { name: 'Ari'},{ name: 'Q'},{ name: 'Sean'},{ name: 'Anand'} ];

在view里我们可以用ng-repeat来遍历这个集合里的数据:

rush:js;">

对赋予ng-repeat的表达式稍作改动,我们还可以用它遍历一个由成对的key-value数据组成的集合。例如,假设我们有一个人名和他们最喜欢的颜色的数据集合:

rush:js;"> $scope.people = { 'Ari': 'orange','Q': 'purple','Sean': 'green' }

要遍历它,我们可以给ng-repeat指令属性赋予这个表达式: (key,value) in object:

rush:js;">

AngularJs Javascript MVC 框架

AngularJs Javascript MVC 框架

在6月google发布了AngularJs 1.0稳定版,

并宣称:AngularJS可以让你扩展HTML的语法,以便清晰、简洁地表示应用程序中的组件,并允许将标准的HTML作为你的模板语言,AngularJS可以通过双向数据绑定自动从拥有JavaScript对 象(模型)的UI(视图)中同步数据。

开始接触AngularJs是在4月份来到新项目组,这时AngularJs还处于0.8未稳定版,项目中已经开始使用了,并且这套框架应用到了项目整个UI端,服务端也是未稳定的web api,真心佩服团队的勇气,对于新技术的热情,幸好大家都能很好的驾驭,这是第一次尝试一个充满未稳定技术的项目。

回到正题,先看一个官方实例:

rush:js;">

总结

以上是小编为你收集整理的AngularJs Javascript MVC 框架全部内容。

如果觉得小编网站内容还不错,欢迎将小编网站推荐给好友。

angularjsjavascriptmvc框架

AngularJS 世界------Angularjs和Javascript以及表达式相关内容

AngularJS 世界------Angularjs和Javascript以及表达式相关内容

在上节我们讲了Angular简介,其中最后说了有 表达式 、指令和模型。
下面三节将依次详细说一下。首先是表达式,那么Angular和Javascrit中的表达式有什么区别呢?

AngularJS 表达式

AngularJS 表达式写在双大括号内:{{ expression }}。
AngularJS 表达式把数据绑定到 HTML,这与 ng-bind 指令有异曲同工之妙。
AngularJS 将在表达式书写的位置”输出”数据。
AngularJS 表达式 很像 JavaScript 表达式:它们可以包含文字、运算符和变量。
实例 {{ 1 + 1 }} 或 {{ a+ ” ” + b }}

<!DOCTYPE html> <html> <head> <Meta charset="utf-8"> <script src="http://apps.bdimg.com/libs/angular.js/1.4.6/angular.min.js"></script> </head> <body> <div ng-app=""> <p>我的第一个表达式: {{ 1 + 1 }}</p> </div> </body> </html>

AngularJS 表达式 与 JavaScript 表达式

类似于 JavaScript 表达式,AngularJS 表达式可以包含字母,操作符,变量。
与 JavaScript 表达式不同,AngularJS 表达式可以写在 HTML 中。
与 JavaScript 表达式不同,AngularJS 表达式不支持条件判断,循环及异常。
与 JavaScript 表达式不同,AngularJS 表达式支持过滤器。

还有AngularJS和JavaScript 中的数字、字符串、对象、数组很像。

数字

<div ng-app="" ng-init="num=2;price=8"> <p>总价: {{ num * price }}</p> </div>

字符串

<div ng-app="" ng-init="a='aaa';b='bbb'"> <p>姓名: {{ a + " " + b }}</p> </div>

对象

<div ng-app="" ng-init="obj={a:'aaa',b:'bbb'}"> <p>姓为 {{ obj.a}}</p> </div>

数组

<div ng-app="" ng-init="arr=[0,1,2,3]"> <p>第三个值为 {{ arr[1] }}</p> </div>

javascript – angularjs ng显示与承诺的表达

javascript – angularjs ng显示与承诺的表达

我正在使用ng-show和一个解析为一个布尔值的承诺的表达式.当我这样做,我得到10个摘要迭代溢出.

见http://plnkr.co/edit/XibYM0kCnXhKjNUeTsp3?p=preview

<body ng-controller="MainCtrl">
    <p ng-show="returnsABoolean()">non promise</p>
    <p ng-show="returnsAPromiseThatResolvesToABoolean()">promise</p>
  </body>

按Ctrl:

$scope.returnsABoolean = ()->
    true

  $scope.returnsAPromiseThatResolvesToABoolean = ()->
    $q.when(false)

我知道{{somePromise}}将会解决,但是{{returnsAPromiseThatResolvesToABoolean()}}似乎引起同样的问题.

有任何想法吗?我期望这个工作..

解决方法

AngularJS自动解决了模板绑定的承诺.然而,您应该使用ng-init中的承诺来阻止摘要循环每次打勾时返回新的承诺.
<p ng-init="v=returnsAPromiseThatResolvesToABoolean()" ng-show="v">promise</p>

javascript – Angularjs – 使用指令来实例化其他指令?

javascript – Angularjs – 使用指令来实例化其他指令?

所以让我们在我的 HTML中说我有这样的东西:
<tabcontent></tabcontent>

那么这个指令的javascript就是这样的:

tabsApp.directive('tabcontent',function(){

  var myObj = {
    priority:0,template:'<div></div>',replace: true,controller: 'TabCtrl',transclude: false,restrict: 'E',scope: false,compile: function (element,attrs){
      return function (parentScope,instanceEle){
        parentScope.$watch('type',function(val) {
          element.html('<div '+val+'></div>');
        });
      }
      $compile(parentScope);
    },link: function postLink(scope,iElement,iAttrs){}
  };
  return myObj;

});

HTML被正确解析,类型的值在控制器JS中找到.

so <tabcontent></tabcontent> is replaced with <div recipe></div> for example..

(那部分确实发生了)

所以我也有一个配方的指令:

tabsApp.directive('recipe',template:'<div>TESTING</div>',attrs){
      return {
        pre: function preLink(scope,iAttrs,controller){},post: function postLink(scope,controller){}
      }
    },iAttrs){}
  };
  return myObj;

});

这显然很简单,只是为了测试.但是配方指令没有被处理…

这里发生了什么?

解决方法

你需要改变2件事情:

>配方指令不能限于E(元素).如果要生成< div recipe>< / div>之类的指令,则至少必须在指令配置上的restrict属性中添加A(属性):

app.directive('recipe',function() {
   return {
      restrict: 'E',...

>您需要在’watch’之后编译tabcontent指令的HTML内容:

app.directive('tabcontent',function($compile){
   return {    
   ...    
   link: function (scope,iAttrs) {
            scope.$watch('type',function(val) {
               iElement.html('<div '+val+'></div>');           
               $compile(iElement.contents())(scope);         
             });
         }
   ...

jsfiddle:http://jsfiddle.net/bmleite/n2BXp/

今天关于详解JavaScript的AngularJS框架中的表达式与指令angular js表达式的介绍到此结束,谢谢您的阅读,有关AngularJs Javascript MVC 框架、AngularJS 世界------Angularjs和Javascript以及表达式相关内容、javascript – angularjs ng显示与承诺的表达、javascript – Angularjs – 使用指令来实例化其他指令?等更多相关知识的信息可以在本站进行查询。

本文标签: