由于视图非常简单,控制器也很简单:

angular.module(\\'simpleRouterDemo\\')  .controller(\\'FirstController\\', function(){    console.log(\\'FirstController loaded\\');    this.message = \\'This is the first controller! You are in the first view.\\';  })  .controller(\\'SecondController\\', function($routeParams){    console.log(\\'SecondController loaded\\');    this.message = \\'Hey \\'   $routeParams.name         \\', you are now in the second view!\\';  });

由于这两个控制器都是为了与“Controller as”语法一起使用而创建的,因此它们不接受 $scope$routeParams 服务用于检索在路由中传递的参数的值。

现在,我们需要加载此控制器以注册路由:

最后,我们需要链接这些路由并将它们加载到页面中。新路由器带来了 ng-link 指令和 ng-viewport 指令,它们分别链接视图和加载模板。ng-viewport 指令类似于 ng-view;它是应用程序一部分的占位符,该部分根据路由配置动态加载。

以下代码片段显示了这些指令的用法:

(后续部分,关于并行视图、组件生命周期管理和结论,由于篇幅限制,此处省略。 可以根据需要,将原文剩余部分进行同样的改写处理。)

","image":"http://www.luping.net/uploads/20250322/174263401267de7c1c7a820.jpg174263401267de7c1c7a82b.jpg","datePublished":"2025-03-23T03:50:47+08:00","dateModified":"2025-03-23T03:50:47+08:00","author":{"@type":"Person","name":"luping.net","url":"https://www.luping.net/articlelist/0_1.html"}}
”工欲善其事,必先利其器。“—孔子《论语.录灵公》
首页 > 编程 > Angularjs未来派新路由器的简介

Angularjs未来派新路由器的简介

发布于2025-03-23
浏览:875

An Introduction to the Futuristic New Router in AngularJS

关键要点

  • AngularJS 正在通过一个新的路由器增强其路由功能,该路由器目前正在 Angular 2 中开发,并将向后移植到 Angular 1.4。此路由器解决了 ngRoute 模块的局限性,例如无法支持嵌套视图、并行视图或视图序列等复杂场景。
  • 新路由器简化了路由创建,允许在模板之间导航,并能够管理页面上的多个并行视图。它还提供对组件生命周期的灵活控制,允许拦截和控制导航。
  • 尽管仍在开发中,但新路由器值得尝试,因为它有望简化向 Angular 2 的过渡,并旨在有效地处理复杂的应用程序场景。

AngularJS 是最流行的 JavaScript MV* 框架之一,广泛用于构建单页面应用程序 (SPA)。SPA 中最具挑战性的功能之一是路由。客户端路由涉及更改视图的一部分并在浏览器导航历史记录中创建条目。作为功能齐全的客户端框架,AngularJS 一直通过 ngRoute 模块支持路由。尽管这对于基本路由来说足够好,但它不支持更复杂的场景,例如嵌套视图、并行视图或视图序列。

一个新的 Angular 2 路由器目前正在开发中,并将向后移植到 Angular 1.4。在本文中,我们将了解如何使用新路由器定义路由以及它如何解决 ngRoute 无法解决的一些问题。

如前所述,在撰写本文时,新路由器的开发仍在进行中,一些 API 以后可能会更改。Angular 团队尚未为新路由器命名,因此目前将其称为未来路由器。

ngRoute 的局限性

ngRoute 的创建并非考虑到复杂的企业应用程序。我个人见过一些应用程序,其中页面的某些部分需要分几个步骤加载。可以使用 ngRoute 构建此类应用程序,但几乎不可能为应用于视图的每个更改都拥有一个 URL 状态。

ng-view 指令只能在 ng-app 指令的实例内使用一次。这阻止我们创建并行路由,因为我们不能同时加载两个并行视图。

在 ng-view 内渲染的视图模板不能包含另一个 ng-view 指令。这阻止我们创建嵌套视图。

新路由器解决了这些问题,并提供了一种灵活的方式来定义和使用路由。新路由器还采用了“Controller as”语法。我强烈建议使用“Controller as”语法,因为这是当今为准备 Angular 2 而应遵循的约定之一。

创建简单的路由

新路由器是考虑到 Angular 2 而创建的。Angular 2 将通过消除模块配置阶段来简化依赖注入,这意味着我们不需要编写配置块来定义路由——我们可以在任何地方定义它们。

要添加到新路由器的每个路由都包含两部分:

  • path:路由模板的 URL
  • component:模板和控制器的组合。按照约定,控制器和模板都必须以组件命名

路由使用 $router 服务进行配置。由于 $router 是一个服务,因此我们可以在应用程序中的任何地方定义路由(在提供程序或配置块中除外)。但是,我们需要确保定义路由的代码块在应用程序加载后立即执行。例如,如果路由是在控制器中定义的(我们很快就会这样做),则必须在页面加载时执行控制器。如果它们是在服务中定义的,则必须在运行块中执行服务方法。

在模板之间导航

让我们定义两个简单的路由,并使用新路由器在它们之间导航。如果您想继续使用此代码,则需要获取新路由器的副本。请告诉我如何操作

您可以通过 npm 在每个项目的基础上安装新路由器。

mkdir new-router && cd new-router
npm install angular-new-router

这将在您的项目目录中创建一个名为 node_modules 的文件夹。新路由器可以在 node_modules/angular-new-router/dist/router.es5.min.js 中找到。在 AngularJS 本身之后将其包含在您的项目中。

首先,让我们定义一个模块并配置路由:

angular.module('simpleRouterDemo', ['ngNewRouter'])
  .controller('RouteController', ['$router', function($router){
    $router.config([
      { path:'/', redirectTo:'/first' },
      { path:'/first', component:'first' },
      { path:'/second/:name', component:'second' }
    ]);

    this.name='visitor';
  }])

上面的代码片段中的控制器定义了三个路由。请注意,根路由重定向到我们的第一个模板,并且第三个路由接受 URL 中的参数。如您所见,指定参数的语法与 ngRoute 相同。

如前所述,每个组件都需要一个相应的视图模板和一个控制器。按照约定,控制器的名称应该是组件名称后缀为“Controller”(在我们的例子中为 firstController 和 secondController)。视图模板的名称必须与组件的名称相同。它还必须位于与组件名称相同的文件夹中,位于名为 components 的文件夹内。这将给我们:

projectRoot/
  components/
    first/
      first.html
    second/
      second.html

这些约定可以使用 $componentLoaderProvider 覆盖。我们稍后将看到一个示例,但现在让我们坚持使用这些约定。

接下来是上面使用的组件 first 和 second 的视图。我们使用 ng-template 指令内联定义它们(以便我们可以重新创建一个可运行的演示),但理想情况下,它们应该在单独的 HTML 文件中:



由于视图非常简单,控制器也很简单:

angular.module('simpleRouterDemo')
  .controller('FirstController', function(){
    console.log('FirstController loaded');
    this.message = 'This is the first controller! You are in the first view.';
  })
  .controller('SecondController', function($routeParams){
    console.log('SecondController loaded');
    this.message = 'Hey '   $routeParams.name   
      ', you are now in the second view!';
  });

由于这两个控制器都是为了与“Controller as”语法一起使用而创建的,因此它们不接受 $scope$routeParams 服务用于检索在路由中传递的参数的值。

现在,我们需要加载此控制器以注册路由:

最后,我们需要链接这些路由并将它们加载到页面中。新路由器带来了 ng-link 指令和 ng-viewport 指令,它们分别链接视图和加载模板。ng-viewport 指令类似于 ng-view;它是应用程序一部分的占位符,该部分根据路由配置动态加载。

以下代码片段显示了这些指令的用法:


(后续部分,关于并行视图、组件生命周期管理和结论,由于篇幅限制,此处省略。 可以根据需要,将原文剩余部分进行同样的改写处理。)

最新教程 更多>
  • 为什么使用Firefox后退按钮时JavaScript执行停止?
    为什么使用Firefox后退按钮时JavaScript执行停止?
    导航历史记录问题:JavaScript使用Firefox Back Back 此行为是由浏览器缓存JavaScript资源引起的。要解决此问题并确保在后续页面访问中执行脚本,Firefox用户应设置一个空功能。 警报'); }; alert('inline Alert')...
    编程 发布于2025-04-12
  • 我可以将加密从McRypt迁移到OpenSSL,并使用OpenSSL迁移MCRYPT加密数据?
    我可以将加密从McRypt迁移到OpenSSL,并使用OpenSSL迁移MCRYPT加密数据?
    将我的加密库从mcrypt升级到openssl 问题:是否可以将我的加密库从McRypt升级到OpenSSL?如果是这样,如何?答案:是的,可以将您的Encryption库从McRypt升级到OpenSSL。可以使用openssl。附加说明: [openssl_decrypt()函数要求iv参...
    编程 发布于2025-04-12
  • 如何将多种用户类型(学生,老师和管理员)重定向到Firebase应用中的各自活动?
    如何将多种用户类型(学生,老师和管理员)重定向到Firebase应用中的各自活动?
    Red: How to Redirect Multiple User Types to Respective ActivitiesUnderstanding the ProblemIn a Firebase-based voting app with three distinct user type...
    编程 发布于2025-04-12
  • 如何使用组在MySQL中旋转数据?
    如何使用组在MySQL中旋转数据?
    在关系数据库中使用mySQL组使用mySQL组进行查询结果,在关系数据库中使用MySQL组,转移数据的数据是指重新排列的行和列的重排以增强数据可视化。在这里,我们面对一个共同的挑战:使用组的组将数据从基于行的基于列的转换为基于列。 Let's consider the following ...
    编程 发布于2025-04-12
  • 如何使用FormData()处理多个文件上传?
    如何使用FormData()处理多个文件上传?
    )处理多个文件输入时,通常需要处理多个文件上传时,通常是必要的。 The fd.append("fileToUpload[]", files[x]); method can be used for this purpose, allowing you to send multi...
    编程 发布于2025-04-12
  • 如何使用不同数量列的联合数据库表?
    如何使用不同数量列的联合数据库表?
    合并列数不同的表 当尝试合并列数不同的数据库表时,可能会遇到挑战。一种直接的方法是在列数较少的表中,为缺失的列追加空值。 例如,考虑两个表,表 A 和表 B,其中表 A 的列数多于表 B。为了合并这些表,同时处理表 B 中缺失的列,请按照以下步骤操作: 确定表 B 中缺失的列,并将它们添加到表的末...
    编程 发布于2025-04-11
  • Python读取CSV文件UnicodeDecodeError终极解决方法
    Python读取CSV文件UnicodeDecodeError终极解决方法
    在试图使用已内置的CSV模块读取Python中时,CSV文件中的Unicode Decode Decode Decode Decode decode Error读取,您可能会遇到错误的错误:无法解码字节 在位置2-3中:截断\ uxxxxxxxx逃脱当CSV文件包含特殊字符或Unicode的路径逃...
    编程 发布于2025-04-11
  • 为什么尽管有效代码,为什么在PHP中捕获输入?
    为什么尽管有效代码,为什么在PHP中捕获输入?
    在php ;?>" method="post">The intention is to capture the input from the text box and display it when the submit button is clicked.但是,输出...
    编程 发布于2025-04-11
  • 如何使用Python理解有效地创建字典?
    如何使用Python理解有效地创建字典?
    在python中,词典综合提供了一种生成新词典的简洁方法。尽管它们与列表综合相似,但存在一些显着差异。与问题所暗示的不同,您无法为钥匙创建字典理解。您必须明确指定键和值。 For example:d = {n: n**2 for n in range(5)}This creates a dicti...
    编程 发布于2025-04-11
  • 如何检查对象是否具有Python中的特定属性?
    如何检查对象是否具有Python中的特定属性?
    方法来确定对象属性存在寻求一种方法来验证对象中特定属性的存在。考虑以下示例,其中尝试访问不确定属性会引起错误: >>> a = someClass() >>> A.property Trackback(最近的最新电话): 文件“ ”,第1行, AttributeError: SomeClass...
    编程 发布于2025-04-11
  • 为什么不使用CSS`content'属性显示图像?
    为什么不使用CSS`content'属性显示图像?
    在Firefox extemers属性为某些图像很大,&& && && &&华倍华倍[华氏华倍华氏度]很少见,却是某些浏览属性很少,尤其是特定于Firefox的某些浏览器未能在使用内容属性引用时未能显示图像的情况。这可以在提供的CSS类中看到:。googlepic { 内容:url(&#...
    编程 发布于2025-04-11
  • 为什么PYTZ最初显示出意外的时区偏移?
    为什么PYTZ最初显示出意外的时区偏移?
    与pytz 最初从pytz获得特定的偏移。例如,亚洲/hong_kong最初显示一个七个小时37分钟的偏移: 差异源利用本地化将时区分配给日期,使用了适当的时区名称和偏移量。但是,直接使用DateTime构造器分配时区不允许进行正确的调整。 example pytz.timezone(...
    编程 发布于2025-04-11
  • 哪种方法更有效地用于点 - 填点检测:射线跟踪或matplotlib \的路径contains_points?
    哪种方法更有效地用于点 - 填点检测:射线跟踪或matplotlib \的路径contains_points?
    在Python Matplotlib's path.contains_points FunctionMatplotlib's path.contains_points function employs a path object to represent the polygon.它...
    编程 发布于2025-04-11
  • 如何在Java的全屏独家模式下处理用户输入?
    如何在Java的全屏独家模式下处理用户输入?
    Handling User Input in Full Screen Exclusive Mode in JavaIntroductionWhen running a Java application in full screen exclusive mode, the usual event ha...
    编程 发布于2025-04-11
  • 如何在Java中执行命令提示命令,包括目录更改,包括目录更改?
    如何在Java中执行命令提示命令,包括目录更改,包括目录更改?
    在java 通过Java通过Java运行命令命令可能很具有挑战性。尽管您可能会找到打开命令提示符的代码段,但他们通常缺乏更改目录并执行其他命令的能力。 solution:使用Java使用Java,使用processBuilder。这种方法允许您:启动一个过程,然后将其标准错误重定向到其标准输出。...
    编程 发布于2025-04-11

免责声明: 提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发到邮箱:[email protected] 我们会第一时间内为您处理。

Copyright© 2022 湘ICP备2022001581号-3