iis服务器助手广告
返回顶部
首页 > 资讯 > 前端开发 > html >AngularJS的指令和表达式是什么
  • 844
分享到

AngularJS的指令和表达式是什么

2024-04-02 19:04:59 844人浏览 安东尼
摘要

angularjs的指令和表达式是什么,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。 指令属性目前为止,我们已提到过几次“指令属

angularjs的指令和表达式是什么,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。

 指令属性

目前为止,我们已提到过几次“指令属性”的概念,但从未深入探讨过它到底是什么。实际上,“指令属性”就是绑定在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

input ng-model="name" name="Name" placeholder="Enter your name"/> <h5>Your name: {{ name }}</h5>

试试看 

AngularJS的指令和表达式是什么

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 }}。

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

  • 所有表达式都在scope这个context里被执行,因此可以使用所有本地 $scope 中的变量。

  • 如果一个表达式的执行导致类型错误或引用错误,这些错误将不会被抛出。

  • 表达式里不允许任何控制函数流程的功能(如if/else等条件语句)

  • 表达式可接受一个或多个串联起来的过滤器。

试试看 

AngularJS的指令和表达式是什么

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

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

现在,让我们回到指令属性&hellip;

ng-init

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

<b ng-init='name = "Ari Lerner"'>Hello, {{ name }}</b>

试试看 

AngularJS的指令和表达式是什么

ng-click

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

<button ng-click="counter = counter + 1">Add one</button> Current counter: {{ counter }}

试试看

AngularJS的指令和表达式是什么

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

<button ng-click="sayHello()">Say hello</button>

controller 里的函数:

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

试试看

AngularJS的指令和表达式是什么

ng-show / ng-hide

The ng-show and ng-hide directives show or hide a portion of the DOM depending on whether the expression is truthy.

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

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

<button ng-init="shouldShow = true" ng-click="shouldShow = !shouldShow">Flip the shouldShow variable</button>  <div ng-show="shouldShow">    <h4>Showing {{ shouldShow }}</h4>  </div> <div ng-hide="shouldShow">    <h4>Hiding {{ shouldShow }}</h4>  </div>

试试看

图6

ng-repeat

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

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

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

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

<ul>    <li ng-repeat="person in roommates">{{ person.name }}</li> </ul>

请看

  • Ari

  • Q

  • Sean

  • Anand

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

请看      Ari     Q     Sean     Anand

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

<ul>    <li ng-repeat="(name, color) in people">{{ name }}'s favorite color is {{ color }}    </li>  </ul>

请看

  • Ari&rsquo;s favorite color is orange

  • Q&rsquo;s favorite color is blue

  • Sean&rsquo;s favorite color is green

Angular.js提供的直接可用的指令属性并不多,但它让我们可以很容易地创建自己的指令属性。请到这里查看我们的指令属性创建指南:http://www.ng-newsletter.com/posts/directives.html

我们应用中的指令属性

在上一篇中,我们的收音机应用只从NPR api取回了***的音频节目列表:

$scope.programs = data.list.story;

现在我们学了遍历一个list的实现方法,可以在我们的收音机应用里,像刚才那样用ng-repeat来遍历这个节目列表了:

<ul id="programs_list" class="">    <li ng-repeat="program in programs">      <span class="large-12">{{ program.title.$text }}</span>    </li> </ul>

NPR API给我们的是一个有title+$text的列表,这个结构是NPR API所特有的,而不是Angular.js的。

现在我们列出了节目和它们的标题,但还不能点击并播放它们。用ng-click我们可以给HTML元素加上一个点击功能:

<ul id="programs_list" class="">    <li ng-repeat="program in programs" ng-click="play(program)">      <span class="large-12">{{ program.title.$text }}</span>    </li> </ul>

通过这一步,我们把一个play动作函数绑定到了列表里的<li>DOM元素上。现在,我们在PlayerController里创建这个play动作函数,然后我们就有了一个功能完备的音频应用:

// fORMat.mp4.$text是NPR API给我们的到这个音频mp4文件的路径 $scope.play = function(program) {    if ($scope.playing) audio.pause();    var url = program.audio[0].format.mp4.$text;    audio.src = url;    audio.play();    // 储存播放器的状态为正在播放    $scope.playing = true; }

现在这个应用功能完备了,但是还不太好看。而且随着我们继续添加新功能,代码也会膨胀,变得难以管理。我们可以创建自己的指令属性,来帮助我们减少复杂性。

想更多地学习自定义指令属性,可以看看我们深入探讨指令属性的文章:http://www.ng-newsletter.com/posts/directives.html

创建自定义指令属性,我们使用app对象的directive方法:

app.directive('nprLink', function() {    return {      restrict: 'EA',      require: ['^ngModel'],      replace: true,      scope: {        ngModel: '=',        play: '&'      },      templateUrl: '/views/nprListItem.html',      link: function(scope, ele, attr) {        scopescope.duration = scope.ngModel.audio[0].duration.$text;      }    } });

我们不会逐个解释每个选项的意义,因为我们有一篇专门的深入文章来介绍它们(http://www.ng-newsletter.com /posts/directives.html)。这里我们只需要明白,现在我们就能在HTML里使用这个自定义的指令属性了,它会将它所在的DOM元素 替换为我们给定的templateUrl所指向的模版里的内容(在 /views/nprListItem 中)。

现在,我们的主HTML文件可以保持整洁,而将用来渲染列表内容的view,创建在这个单独提取出来的模版文件里:

<div class="nprLink row" ng-click="play(ngModel)">    <span class="name large-8 columns">      <button class="large-2 small-2 playButton columns"><div class="triangle"></div></button>      <div class="large-10 small-10 columns">        <div class="row">          <span class="large-12">{{ ngModel.title.$text }}</span>        </div>        <div class="row">          <div class="small-1 columns"></div>          <div class="small-2 columns push-8"><a href="{{ ngModel.link[0].$text }}">Link</a></div>        </div>      </div>    </span>  </div>

注意我们在模版文件里用ngModel来指向之前的program数据,因为在创建自定义指令属性时,我们做了设置。

现在,我们在主HTML文件里就不用再写上面那么多HTML,而只要简单地换上我们的自定义指令属性npr-link:

<ul id="programs_list" class="">    <li ng-repeat="program in programs">      <span npr-link play='play(program)' ng-model="program"></span>    </li> </ul>

要将这个代码库保存到本地,请先确保安装了git,clone此代码库,然后check out其中的part5分支。我们使用XHR获取模版,所以你需要在本地服务器上运行这一章的代码。在part5分支里我们提供了服务器端代码:

git clone https://GitHub.com/auser/ng-newsletter-beginner-series.git git checkout -b part5 ./bin/server.sh

关于AngularJS的指令和表达式是什么问题的解答就分享到这里了,希望以上内容可以对大家有一定的帮助,如果你还有很多疑惑没有解开,可以关注编程网html频道了解更多相关知识。

--结束END--

本文标题: AngularJS的指令和表达式是什么

本文链接: https://www.lsjlt.com/news/86311.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • AngularJS的指令和表达式是什么
    AngularJS的指令和表达式是什么,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。 指令属性目前为止,我们已提到过几次“指令属...
    99+
    2024-04-02
  • javascript的表达式指的是什么
    这篇文章主要讲解了“javascript的表达式指的是什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“javascript的表达式指的是什么”吧! ...
    99+
    2024-04-02
  • 什么指的是正则表达式
    这篇文章给大家分享的是有关什么指的是正则表达式的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。1. 什么是正则表达式基本说来,正则表达式是一种用来描述一定数量文本的模式。Regex代表Regular Express...
    99+
    2023-06-17
  • php正则表达式指的是什么
    这篇文章主要介绍了php正则表达式指的是什么的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇php正则表达式指的是什么文章都会有所收获,下面我们一起来看看吧。在php中,正则表达式是描述字符排列模式的一种自定义语...
    99+
    2023-07-05
  • vue插值表达式和v-text指令的区别
    目录1.使用插件表达式2.在插件表达式中使用v-cloak解决闪烁问题3.插件表达式{{message}} 语法只能在标签内容中使用 {{}}这种语法叫做插值表达式,在插值表达式中可...
    99+
    2024-04-02
  • php不模糊包含表达式指的是什么
    本文小编为大家详细介绍“php不模糊包含表达式指的是什么”,内容详细,步骤清晰,细节处理妥当,希望这篇“php不模糊包含表达式指的是什么”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。不模糊包含表达式是指匹配字符串...
    99+
    2023-07-05
  • LINQ表达式是什么
    这篇文章主要讲解了“LINQ表达式是什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“LINQ表达式是什么”吧!LINQ表达式简介OO(面向对象)以外的疆域:信息的访问与整合。关系数据库与X...
    99+
    2023-06-17
  • 什么是css表达式
    什么是css表达式,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。 css表达式就是在css属性后使用expre...
    99+
    2024-04-02
  • javascript表达式是什么
    这篇文章将为大家详细讲解有关javascript表达式是什么,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。 javascript表达式有:1、...
    99+
    2024-04-02
  • JavaScript中的表达式是什么
    今天给大家介绍一下JavaScript中的表达式是什么。文章的内容小编觉得不错,现在给大家分享一下,觉得有需要的朋友可以了解一下,希望对大家有所帮助,下面跟着小编的思路一起来阅读吧。在JavaScript中...
    99+
    2024-04-02
  • python中什么是表达式
    今天就跟大家聊聊有关python中什么是表达式,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。说明Python表达式是变量、常量、计算符和方法调用的序列,它执行指定的计算,并返回某个确...
    99+
    2023-06-20
  • C++ 函数指针与 lambda 表达式的比较和对比是什么?
    函数指针和 lambda 表达式都是 c++++ 中封装代码块的技术,各有不同。函数指针是指向函数内存地址的常量指针,而 lambda 表达式是匿名函数,语法更灵活,可捕获外部变量。函数...
    99+
    2024-04-17
    c++ 函数指针
  • python lambda表达式的格式是什么
    本篇内容介绍了“python lambda表达式的格式是什么”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!前言:在日常开发的过程中...
    99+
    2023-06-29
  • Linq Lambda表达式是什么
    本篇内容介绍了“Linq Lambda表达式是什么”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!Linq Lambda表达式许多标准查询操作...
    99+
    2023-06-17
  • cron表达式的作用是什么
    cron表达式用于指定定时任务的执行时间。它是一个字符串,由6个或7个字段组成,分别表示秒、分钟、小时、日期、月份、星期和年份(可选...
    99+
    2023-08-12
    cron表达式
  • Java中的Lambda表达式是什么
    这篇文章主要介绍“Java中的Lambda表达式是什么”,在日常操作中,相信很多人在Java中的Lambda表达式是什么问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Java中的Lambda表达式是什么”的疑...
    99+
    2023-06-25
  • Angularjs中的视图和指令介绍
    这篇文章主要介绍“Angularjs中的视图和指令介绍”,在日常操作中,相信很多人在Angularjs中的视图和指令介绍问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Angu...
    99+
    2024-04-02
  • vue插值表达式和v-text指令的区别有哪些
    小编给大家分享一下vue插值表达式和v-text指令的区别有哪些,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!{{message}} 语法只能在标签内容中使用{{...
    99+
    2023-06-25
  • C语言表达式是什么
    这篇文章主要介绍“C语言表达式是什么”,在日常操作中,相信很多人在C语言表达式是什么问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”C语言表达式是什么”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!C语言表达...
    99+
    2023-06-17
  • 什么是VB.NET正则表达式
    这篇文章主要介绍了什么是VB.NET正则表达式,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。1.什么是VB.NET正则表达式 基本说来,正则表达式是一种用来描述一定数量文本的...
    99+
    2023-06-17
软考高级职称资格查询
推荐阅读
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作