iis服务器助手广告
返回顶部
首页 > 资讯 > 前端开发 > JavaScript >如何使用 AngularJS开发一个大规模的单页应用
  • 150
分享到

如何使用 AngularJS开发一个大规模的单页应用

2024-04-02 19:04:59 150人浏览 薄情痞子
摘要

今天就跟大家聊聊有关如何使用 angularjs开发一个大规模的单页应用,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。介绍(SPA)这样一个名字里面

今天就跟大家聊聊有关如何使用 angularjs开发一个大规模的单页应用,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。


介绍

(SPA)这样一个名字里面蕴含着什么呢? 如果你是经典的Seinfeld电视秀的粉丝,那么你一定知道Donna Chang这个名字。Jerry跟Donna见面,Donna其实不是华人,但是却因在谈论其对中国的固有印象比如在针灸上的兴趣,以及偶然的一次单词发音带上了点儿中文口音,她将自己末尾的名字缩成了Chang Donna 在电话上同George的母亲交谈,(通过引用孔子)给她提了些建议。当George向自己的父母介绍Donna是,George的母亲意识到Donna并不是华人,因此并没有接受Donna的建议.

单页面引用 (SPA), 被定义成一个目的在于提供一种接近桌面应用程序的流畅用户体验单WEB页面应用程序,或者说网站. 在一个SPA中, 所有必需的代码 – html, javascript, 以及 CSS – 都是在单页面加载的时候获取,或者相关的资源被动态的加载并按需添加到页面中, 这常常是在响应用户动作的时候发生的. 尽管现代的Web技术(比如那些在HTML5中引入的技术)提供了应用程序中各自独立的逻辑页面相互感知和导航的能力,页面却不会在过程中重新加载任何端点,或者将控制转到另外一个页面. 同单页面应用程序的交互常常设计到同位于后台的web服务器的动态交互.

那么拿这项技术同 asp.net 的母版页Master Pages相比呢? 诚然 ASP.net 的母版页让你可以为自己应用程序里的页面创建一个一直的布局。一个单独的母版页就可以定义好你想要在整个应用程序中的所有页面(或者一组页面)上应用的外观和标准动作. 然后你就可以再来创建你想要展示的内容各自独立页面. 当用户发起对内容页面的请求时,它们会将来自母版页的布局和来自内容页面的内容混合到一起,产生输出.

当你深入研究SPA和ASP.NET母版页实现这两者之间的不同时,你就开始会意识到它们之间相同的地方多于不同的地方——那就是SPA可以看做是一个简单的装着内容页面的外壳页面,就像是一个母版页, 只是SPA中的外壳页面不能像母版页那样根据每一个新的页面请求来重新装载和执行.

也许“单页面应用”是个不幸运的名字(像唐娜`程一样),让你相信这个技术不适合开发需要拓展到企业级,可能 包含上百页面以及数千用户的Web应用。

基于单页面应用程序开发出拥有数百页的内容,包括认证,授权,会话状态等功能,可以支持上千个用户的企业级应用。

AngularJS - 概述 

本文的样例包含的功能有创建/跟新用户账号,创建/更新客户和产品。而且,它还允许用户针对所有信息执行查询,创建和跟新销售订单。为了实现这些功能,该样例将会基于AngularJS来开发。 AngularJS 是一个由Google和AngularJS社区的开发人员维护的开源的Web应用框架

AngularJS仅需HTML,CSS和JavaScript就可在客户端创建单页面应用。它的目标是是开发和测试更容易,增强mvc Web应用的性能。

这个库读取HTML中包含的其他定制的标签属性;然后服从这个定制的属性的指令,把页面的I/O结合到有标准JavaScript变量生成的模块中。这些JavaScript标准变量的值可以手动设置,或者从静态或动态的JSON数据源中获取。

如何使用 AngularJS开发一个大规模的单页应用

AngularJS使用入门 - 外壳页面,模块和路由
 

你首先要做的一件事情就是讲AngularJS框架下载到你的项目中,你可以从 https://angularjs.org 获得框架. 本文的示例程序是使用MS Visual Studio Web Express 2013 Edition开发的,因此我是使用如下的命令从一个Nuget包安装AngularJS的:

Install-Package AngularJS -Version 1.2.21

Nuget包管理控制台上. 为了保持简单和灵活性,我创建了一个空的 Visual Studio web 应用程序项目,并将Microsoft Web api 2库选进了核心引用. 这个应用程序将使用Web API 2 库来实现 RESTful API 的服务器端请求.

现在当你要使用AngularJS创建一个SPA应用程序是,首先要做的两件事情就是设置一个外壳页面,以及用于获取内容页面的路由表. 开始的时候,外壳页面只需要一个队AngularJS JavaScript库的引用,还有一个ng-view,来告诉AngularJS内容页面需要在外壳页面的那个地方被渲染.

<!DOCTYPE html> <html lang="en"> <head> <title>AngularJS shell Page example</title> </head> <body>   <div> <ul> <li><a href="#Customers/AddNewCustomer">Add New Customer</a></li> <li><a href="#Customers/CustomerInquiry">Show Customers</a></li> </ul> </div> <!-- ng-view directive to tell AngularJS where to inject content pages --> <div ng-view></div> <script src="Http://ajax.googleapis.com/ajax/libs/angularjs/1.0.7/angular.min.js"></script> <script src="app.js"></script> </body> </html>

在上面的外壳页面示例中,几个链接呗映射到了AngularJS的路由。div标签上的ng-view指令是一个能将选定路由的被渲染内容页面包含到外壳页面来补充AngularJS的$route服务的指令. 每次当目前的路由变化时,包含的视图也会根据$route服务的配置随之改变. 比如,当用户选择了 "Add New Customer" 链接,AngularJS 就会在ng-view所在的div里面渲染用于添加一个新顾客的内容 . 被渲染的内容是一个HTML片段.

下来的app.js文件同样也被外壳页面引用了。这个文件里的JavaScript将会为应用程序创建AngularJS模块。此外,应用程序所有的路由配置也会在这个文件中定义。你可以把一个AngularJS模块想象成封装你应用程序不同部分的容器。大多数的应用程序都会有一个主方法,用来初始化应用程序的不同部分,并将它们联系起来。AngularJS应用程序却没有一个主方法,而是让模块声明性的指定应用程序如何启动和配置. 本文的示例程序将只会有一个AngularJS模块,虽然应用程序中存在几个明显不同的部分(顾客,产品,订单和用户).

现在,app.js的主要目的就是如下所示,用来设置AngularJS的路由。AngularJS的$routeProvider服务会接受  when() 方法,它将为一个Uri匹配一个模式. 当发现一次匹配时,独立页面的HTML内容会跟随相关内容的控制器文件一同被加载到外壳页面中. 控制器文件就简单的只是一个JavaScript文件,它将获得带有某个特定路由请求内容的引用.

//Define an angular module for our app  var sampleApp = angular.module(&apos;sampleApp&apos;, []);  //Define Routing for the application  sampleApp.config([&apos;$routeProvider&apos;,      function($routeProvider) {          $routeProvider.              when(&apos;/Customers/AddNewCustomer&apos;, {                  templateUrl: &apos;Customers/AddNewCustomer.html&apos;,                  controller: &apos;AddNewCustomerController&apos;              }).              when(&apos;/Customers/CustomerInquiry&apos;, {                  templateUrl: &apos;Customers/CustomerInquiry.html&apos;,                  controller: &apos;CustomerInquiryController&apos;              }).              otherwise({                  redirectTo: &apos;/Customers/AddNewCustomer&apos;              });  }]);
AngularJS 的控制器
 

AngularJS 控制器无非就是一个原生的JavaScript函数,只是被绑定到了一个特定的范围而已。控制器用来将逻辑添加到你的视图。视图就是HTML页面。这些页面只是做简单的数据展示工作,我们会使用双向数据绑定来将数据绑定到这些HTML页面上. 将模型(也就是数据)同数据粘合起来基本山就是控制器的职责了.

<div ng-controller="customerController"> <input ng-model="FirstName" type="text" style="width: 300px" /> <input ng-model="LastName" type="text" style="width: 300px" />         <div> <button class="btn btn-primary btn-large" ng-click="createCustomer()"/>Create</button>

对于上面的AddCustomer模板,ng-controller指令将会引用JavaScript函数customerController,这个控制会执行所有的数据绑定以及针对该视图的JavaScript函数.

function customerController($scope)   {      $scope.FirstName = "William";      $scope.LastName = "Gates";          $scope.createCustomer = function () {                    var customer = $scope.createCustomerObject();          customerService.createCustomer(customer,                           $scope.createCustomerCompleted,                           $scope.createCustomerError);      }  }
开箱即用 - 可扩展性问题
 

当我为本文开发这个实力程序时,首当其冲的两个扩展性问题在应用单页面应用程序时变得明显起来。其实一个开箱即用,AngularJS需要应用程序的外壳页面中所有的JavaScript文件和控制器在启动中伴随应用程序的启动被引入和下载. 对于一个大型的应用程序而言,可能会有上百个JavaScript文件,这样情况看上去就会不怎么理想。我遇到的另外一个问题就是AngularJS的路由表。我找到的所有示例都有针对所有内容的所有路由的硬编码。而我想要的确不是一个在路由表里包含上百项路由记录的方案.

看完上述内容,你们对如何使用 AngularJS开发一个大规模的单页应用有进一步的了解吗?如果还想了解更多知识或者相关内容,请关注编程网JavaScript频道,感谢大家的支持。

--结束END--

本文标题: 如何使用 AngularJS开发一个大规模的单页应用

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

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

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

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

下载Word文档
猜你喜欢
  • 如何使用 AngularJS开发一个大规模的单页应用
    今天就跟大家聊聊有关如何使用 AngularJS开发一个大规模的单页应用,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。介绍(SPA)这样一个名字里面...
    99+
    2024-04-02
  • 如何使用Kotlin开发一个Android应用
    如何使用Kotlin开发一个Android应用?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。第一步:为AndroidStudio安装Kotlin插件在线安装步骤...
    99+
    2023-05-30
    android kotlin
  • AngularJS中如何使用应用模块化
    这篇文章主要介绍AngularJS中如何使用应用模块化,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!一.模块化的好处(1)实现逻辑更清晰、可读性强;(2)团队开发分工明确,容易控制;...
    99+
    2024-04-02
  • 如何开发一个springboot应用
    本文小编为大家详细介绍“如何开发一个springboot应用”,内容详细,步骤清晰,细节处理妥当,希望这篇“如何开发一个springboot应用”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。如何编写 spring...
    99+
    2023-06-30
  • 如何使用MongoDB开发一个简单的 CRUD API
    如何使用MongoDB开发一个简单的CRUD API在现代的Web应用程序开发中,CRUD(增删改查)操作是非常常见和重要的功能之一。在本文中,我们将介绍如何使用MongoDB数据库开发一个简单的CRUD API,并提供具体的代码示例。Mo...
    99+
    2023-10-22
    API MongoDB CRUD
  • 如何用Go语言开发一个简单的聊天应用
    如何用Go语言开发一个简单的聊天应用随着互联网的快速发展,聊天应用成为人们日常生活中不可或缺的一部分。而Go语言作为一种快速、可靠和高效的编程语言,越来越受到开发者的青睐。本文将介绍如何用Go语言开发一个简单的聊天应用。一、项目概述我们将使...
    99+
    2023-11-20
    Go语言开发 简单聊天应用 聊天程序
  • 如何使用requirejs模块化开发多页面一个入口js
    这篇文章主要为大家展示了“如何使用requirejs模块化开发多页面一个入口js”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“如何使用requirejs模块化开...
    99+
    2024-04-02
  • Django开发中如何使用Java API处理大规模数据?
    在Django开发中,我们经常需要处理大规模数据,而Java作为一种高效的编程语言,可以提供很好的解决方案。在本文中,我们将介绍如何使用Java API处理大规模数据,以优化Django开发过程中的数据处理和分析。 首先,我们需要安装Jav...
    99+
    2023-10-27
    api django bash
  • 使用Kotlin如何实现开发一个Android应用
    今天就跟大家聊聊有关使用Kotlin如何实现开发一个Android应用,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。配置项目gradle文件apply plugin: 'co...
    99+
    2023-05-31
    kotlin android roi
  • 从零开始,如何用Go语言开发一个简单的Web应用
    从零开始,如何用Go语言开发一个简单的Web应用简介:Go语言是一种开源的编程语言,它具有高效、简洁以及并发编程的优势,因此在Web应用的开发中越来越受到开发者的欢迎。本文将指导读者从零开始,使用Go语言来开发一个简单的Web应用。步骤一:...
    99+
    2023-11-20
    开发 Go语言 Web应用
  • 如何用Go语言开发一个简单的即时通讯应用
    如何用Go语言开发一个简单的即时通讯应用随着互联网的发展和人们对实时沟通需求的增加,即时通讯应用在我们生活中扮演着越来越重要的角色。Go语言作为一种开源的高性能编程语言,越来越受开发者们的喜爱。本文将介绍如何使用Go语言开发一个简单的即时通...
    99+
    2023-11-20
    开发 即时通讯 关键词:Go语言
  • 如何用Go语言开发一个简单的社交网络应用
    如何用Go语言开发一个简单的社交网络应用引言社交网络已经成为人们日常生活中不可或缺的一部分。随着技术的发展,开发一个属于自己的社交网络应用已经变得越来越简单。本文将以Go语言为开发工具,介绍如何快速开发一个简单的社交网络应用。第一步:设计数...
    99+
    2023-11-20
    开发 Go语言 社交网络
  • vue.js 中怎么构建一个大型单页应用
    本篇文章为大家展示了vue.js 中怎么构建一个大型单页应用,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。前置条件:熟悉使用 Javascript + HTML5 ...
    99+
    2024-04-02
  • Vue 2.0+Vue-router如何构建一个简单的单页应用
    这篇文章主要介绍Vue 2.0+Vue-router如何构建一个简单的单页应用,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!一、介绍vue.js 是 目前 最火的前端框架,vue.j...
    99+
    2024-04-02
  • 如何使用Vue做一个简单的todo应用
    小编给大家分享一下如何使用Vue做一个简单的todo应用,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!1. 引用vue.js&l...
    99+
    2024-04-02
  • Redis在PHP中的应用:大规模数据的分页
    随着互联网的普及和发展,大规模数据的处理已经成为了各个领域中不可避免的需求。在Web应用中,分页展示数据是常用的方式之一,但是在处理大规模数据时,分页效率会受到很大的影响。这时,Redis这个高性能的内存数据存储系统就可以发挥它的优势,提高...
    99+
    2023-05-17
    分页 PHP redis
  • 如何使用MongoDB开发一个简单的区块链系统
    如何使用MongoDB开发一个简单的区块链系统区块链技术近年来备受关注,因其去中心化、安全性高等特点,被广泛用于加密货币、合约管理等领域。本文将介绍如何使用MongoDB开发一个简单的区块链系统,并提供相应的代码示例。1.安装和配置Mong...
    99+
    2023-10-22
    开发 区块链 MongoDB
  • 使用React-Router怎么创建一个单页应用
    使用React-Router怎么创建一个单页应用,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。什么是路由以下来自维基百科::路...
    99+
    2024-04-02
  • 如何使用HBuilderX开发一个简单的微信小程序
    这篇文章将为大家详细讲解有关如何使用HBuilderX开发一个简单的微信小程序,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。一、配置在微信开发者工具的设置中开启,如图:在HBuilderX中新建项目,选择...
    99+
    2023-06-29
  • 如何使用MongoDB开发一个简单的物联网系统
    如何使用MongoDB开发一个简单的物联网系统摘要:物联网系统是当前技术领域的热门话题,它将物理设备与互联网连接起来,使得设备之间可以实现数据的交互与共享。本文将介绍如何使用MongoDB开发一个简单的物联网系统,并提供代码示例供读者参考。...
    99+
    2023-10-22
    开发 物联网 MongoDB
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作