当前位置: 首页 > 面试题库 >

$ routeProvider和$ stateProvider有什么区别?

胡和煦
2023-03-14
问题内容

请解释AngularJS $routeProvider和之间的区别$stateProvider

哪个是最佳做法?


问题答案:

两者的功能与SPA(单页应用程序)中用于路由目的的功能相同。

1.角路由-每个[$

routeProvider文档](https://docs.angularjs.org/api/ngRoute/provider/$routeProvider)

控制器和视图的URL(HTML局部)。它监视$ location.url()并尝试将路径映射到现有的路由定义。

的HTML

<div ng-view></div>

上面的标签将根据$routeProvider.when()您在.config角度(配置阶段)中提到的条件来渲染模板

局限性

  • 该页面只能包含一个ng-view页面
  • 如果您的SPA在某些情况下要在页面上显示多个小组件,则$routeProvider失败。(实现这一目标,我们需要使用指令一样ng-includeng-switchng-ifng-show,这看起来不错,让他们在SPA)
  • 您不能在两条路线之间建立联系,例如父子关系。
  • 您无法基于URL模式显示和隐藏视图的一部分。

2. ui- [router-](http://angular-ui.github.io/ui-

router/site/#/api/ui.router.state.$stateProvider)每个$
stateProvider文档

AngularUI Router是AngularJS的路由框架,它允许您将接口的各个部分组织到状态机中。UI-
Router是围绕状态组织的,状态可以有选择地附加路由以及其他行为。

多个视图和命名视图

另一个重要功能是能够在模板中具有多个ui视图。

虽然多个并行视图是一个强大的功能,但是您通常可以通过嵌套views并将这些视图与嵌套状态配对来更有效地管理接口。

的HTML

<div ui-view>
    <div ui-view='header'></div>
    <div ui-view='content'></div>
    <div ui-view='footer'></div>
</div>

的大部分ui-router功能是它可以管理嵌套状态和视图。

优点

  • 您可以ui-view在一个页面上有多个
  • 各种视图可以彼此嵌套,并可以通过在路由阶段定义状态来维护。
  • 我们可以在这里具有子级和父级关系,就像在状态中继承一样,也可以定义同级状态。
  • 您可以ui-view="some"仅通过使用@带有状态名称的绝对路由来更改状态。
  • 进行相对路由的另一种方法是仅@使用change ui-view="some"。这将代替ui-view而不是检查是否嵌套。
  • 在这里,您可以用来根据状态中提到的内容动态ui-sref创建hrefURL URL,也可以使用json格式指定状态参数。

有关更多信息Angular ui-router

为了更好地处理带有状态的各种嵌套视图,我希望您能使用 ui-router



 类似资料:
  • 问题内容: 两者都意味着空间,但是有什么区别吗? 问题答案: 一个是不间断空间,另一个是常规空间。不间断的空格表示该行不应在该点处换行,就像它不会在一个单词的中间换行一样。 此外,正如斯文德(Svend)在其评论中指出的那样,不间断的空间不会崩溃。

  • 本文向大家介绍<%# %> 和 <% %> 有什么区别?相关面试题,主要包含被问及<%# %> 和 <% %> 有什么区别?时的应答技巧和注意事项,需要的朋友参考一下 答:<%# %>表示绑定的数据源 <%%>是服务器端代码块  

  • 问题内容: 以下代码之间有什么区别: 和 Python建议采用一种做事方式,但有时似乎不止一种。 问题答案: 一个是函数调用,一个是文字: 使用第二种形式。它更具Python风格,并且可能更快(因为它不涉及加载和调用单独的函数)。

  • 发展至今(2020 年 6 月份),GCC 编译器已经更新至 10.1.0 版本,其功能也由最初仅能编译 C 语言,扩增至可以编译多种编程语言,其中就包括 C++ 。 除此之外,当下的 GCC 编译器还支持编译 Go、Objective-C,Objective-C ++,Fortran,Ada,D 和 BRIG(HSAIL)等程序,甚至于 GCC 6 以及之前的版本还支持编译 Java 程序。但本

  • 问题内容: 比较PMD和CheckStyle有一个问题。但是,我找不到关于PMD和FindBugs之间差异/相似性的详尽分类。我相信一个关键的区别是PMD适用于源代码,而FindBugs适用于编译的字节码文件。但是就功能而言,这应该是一个选择,还是两者相辅相成? 问题答案: 我同时使用。我认为他们是相辅相成的。 正如您所说,PMD在源代码上工作,因此会发现诸如以下问题:违反命名约定,缺少花括号,放

  • 问题内容: 我被要求在portlet和门户网站上工作。 我想知道portlet和servlet之间的区别吗? Portlet与Servlet有何不同之处(可能在功能上)? 问题答案: Portlet是JSR-168标准的一部分,该标准规范门户容器和组件。这与Web容器(和Servlet)的标准不同。尽管这两个标准之间肯定有很强的相似之处,但是它们在容器,API,生命周期,配置,部署等方面有所不同。