AngularJS Seed 是典型 AngularJS web 应用的应用骨架,可以快速启动你的 AngularJS webapp 项目和这些项目的开发环境。

AngularJS Seed 包括一个示例 AngularJS 应用,预配置安装 Angular 框架,为满足即时 Web 开发提供一些开发和测试工具。

Seed 应用只是展示如何连接两个控制器和视图。。


开始

准备条件

你需要先用 git 将angular-seed克隆到自己的本地,然后安装它的依赖。

如果你没有安装过git,你可已再 http://git-scm.com/获取他。

当然我们还需要用node.js来初始化和测试angular-seed,如果你没有安装node.js及相应的NPM,你可以从http://nodejs.org/获取它。

克隆 angular-seed

使用git克隆 angular-seed,并进入 angular-seed目录

  1. git clone https://github.com/angular/angular-seed.git
  2. cd angular-seed

如果你想获取没有历史commit的Angular-seed源码,请使用

  1. git clone --depth=1 https://github.com/angular/angular-seed.git <your-project-name>

安装依赖

angular-seed已经预先设定npm去自动运行bower,所以我们能这样简单运行:

  1. npm install

后面的场景,也将调用bower install。安装后,你能发现有两个新文件夹在你的项目中。

  • node_modules - 包含我们需要的npm工具包。
  • app/bower_components - 包含angular的框架文件。

运行项目

angular-seed已经预先项目带有一个简单的开发Web服务器,我们可以很简单的启动它。

  1. npm start

在浏览器中访问应用程序,http://localhost:8000/index.html

目录结构

  1. app/-->项目的源文件
  2. app.css -->默认的css文件
  3. components/-->所有应用程序的特定模块
  4. version/-->相关的组件
  5. version.js -->基本模块的声明
  6. version_test.js -->基本模块的测试
  7. version-directive.js -->用户定义的指令
  8. version-directive_test.js -->用户定义的指令测试
  9. interpolate-filter.js -->用户定义的过滤器
  10. interpolate-filter_test.js -->用户定义的过滤器测试
  11. view1/--> view1视图模板和控制器
  12. view1.html -->局部模板
  13. view1.js -->控制器
  14. view1_test.js -->控制器的测试
  15. view2/--> view2视图模板和控制器
  16. view2.html -->局部模板
  17. view2.js -->控制器
  18. view2_test.js -->控制器的测试
  19. app.js -->主项目模块
  20. index.html -->项目布局模板
  21. index-async.html -->就像index.html,但异步加载JS文件
  22. karma.conf.js -->用于运行karma单元测试的配置文件
  23. e2e-tests/-->端对端测试
  24. protractor-conf.js -->Protractor配置文件
  25. scenarios.js -->Protractor端对端测试的运行文件

测试

有两种测试,单元测试和端对端测试。

运行单元测试

angular-seed预先配置了单元测试。它们是Jasmine写的,我们使用 Karma测试运行器运行它。有一个默认的 Karma文件去运行它。

  • 你能在karma.conf.js查看单元测试配置。
  • 每个运行的代码下有它对应的单元测试代码,并命名为..._test.js

最简单的运行单元测试,使用以下脚本:

  1. npm test

这句命令将启动 Karma来执行单元测试。而且, Karma会监控代码和测试文件的变化,并重新运行单元测试。但每次更改都运行单元测试,可能会打破你预期的代码功能。

你也可以叫Karma运行简单的单元测试后就退出。这样可有效的检验一个特定版本的代码是否是按预期运行的。使用下面的脚本:

  1. npm run test-single-run

端对端测试

angular-seed预先配置的端对端测试是用 Jasmine写的,用 Protractor端对端测试器运行它。它使用本地事件,并对angular应用具有特殊功能。

  • 你能在e2e-tests/protractor-conf.js查看端对端测试配置。
  • 运行e2e-tests/scenarios.js进行端对端测试。

Protractor模拟与我们的Web应用程序的交互并且验证应用程序是否正确响应。所以,我们的web服务器必须能被应用程序正常的打开,以便Protractor能与它互动。使用下面的脚本:

  1. npm start

运行Protractor需要先安装 WebDriver,angular-seed使用以下代码安装它:

  1. npm run update-webdriver

这句脚本将会下载并安装最新的独立的WebDriver工具。

确保你的web服务器环境运行起来了,并且 WebDriver已经更新过了,你可以进行端对端测试了,运行以下代码:

  1. npm run protractor

提醒: Protractor使用Selenium Standalone Server,这需要你的本地机器安装了Java Development Kit (JDK)。在命令行输入 java -version检查下JDK是否安装。

若没安装,你可以点击这里下载它。

angular-seed — AngularJS种子项目的更多相关文章

  1. Angular系列----AngularJS入门教程00:引导程序(转载)

    我们现在开始准备编写AngularJS应用——phonecat.这一步骤(步骤0),您将会熟悉重要的源代码文件,学习启动包含AngularJS种子项目的开发环境,并在浏览器端运行应用. 进入angul ...

  2. 迈向angularjs2系列(8):angular cli和angular2种子项目

    文章目录 1.angular cli快速搭建项目 2.angular2-seed 3.手动配置 题外话:如何更好的阅读本篇文章 一: angular cli的安装 Angular-cli(命令行界面, ...

  3. Angular企业级开发(5)-项目框架搭建

    1.AngularJS Seed项目目录结构 AngularJS官方网站提供了一个angular-phonecat项目,另外一个就是Angular-Seed项目.所以大多数团队会基于Angular-S ...

  4. Angular系列------AngularJS入门教程:导言和准备(转载)

    学习AngularJS的一个好方法是逐步完成本教程,它将引导您构建一个完整的AngularJS web应用程序. 该web应用是一个Android设备清单的目录列表,您可以筛选列表以便查看您感兴趣的设 ...

  5. Angular系列---- AngularJS入门教程03:AngularJS 模板(转载)

    是时候给这些网页来点动态特性了——用AngularJS!我们这里为后面要加入的控制器添加了一个测试. 一个应用的代码架构有很多种.对于AngularJS应用,我们鼓励使用模型-视图-控制器(MVC)模 ...

  6. Angular系列----AngularJS入门教程01:AngularJS模板 (转载)

    是时候给这些网页来点动态特性了——用AngularJS!我们这里为后面要加入的控制器添加了一个测试. 一个应用的代码架构有很多种.对于AngularJS应用,我们鼓励使用模型-视图-控制器(MVC)模 ...

  7. AngularJS+requireJS项目的目录结构设想

    AngularJS+requireJS项目的目录结构设想 准备用AngularJS + require.js 作为新项目的底层框架,以下目录结果只是一个初步设想: /default    放页面,不过 ...

  8. Github+yeoman+gulp-angular初始化搭建angularjs前端项目框架

    在上篇文章里面我们说到了Github账号的申请与配置 那么当你有了Github账号并创建了一个自己的Github项目之后,首要的当然是搭建自己的项目框架啦! 本人对自己的定位是web前端狗,常用开发框 ...

  9. JAVA8,SPRING,ANGULARJS对项目

    java8+spring+angularjs 项目应用 最近有写一个电子订单商务网站,使用JAVA8,SPRING,ANGULARJS对项目使用的技术和大家分享. 第一次写博客,哪有不对需要改正的请联 ...

随机推荐

  1. 《Python编程从0到1》笔记5——图解递归你肯定看完就能懂!

    本小节的示例比较简单,因为在每次递归过程中原问题仅缩减为单个更小的问题.这样的问题往往能够用简单循环解决.这类递归算法的函数调用图是链状结构.这种递归类型被称为“单重递归”(single recurs ...

  2. windows VS2013中使用<pthread.h>

    1. 下载pthreads-w32-2-9-1-realease.zip 地址:http://www.mirrorservice.org/sites/sourceware.org/pub/pthrea ...

  3. PTA(Basic Level)1010.一元多项式求导

    设计函数求一元多项式的导数.(注:\(x^n\)(\(n\)为整数)的一阶导数为\(nx^{n−1}\).) 输入格式: 以指数递降方式输入多项式非零项系数和指数(绝对值均为不超过 1000 的整数) ...

  4. 索引之----mysql单列索引失效的情况

    使用的索引名称: 1.隐式转换导致索引失效. 由于表字段定义为vachar类型,但在查询时把该字段作为number类型 以及where条件传给mysql. 2.对索引列进行任何操作(计算(+.-.*. ...

  5. jsp运行环境的安装和配置

    1.JDK的安装和配置 1)下载jdk,我下载的是1-jdk-6u26-windows-i586.exe,放在D:\StudySystem\JavaWeb\jdk目录下. 2)安装jdk,直接你下载的 ...

  6. Nginx_Ubuntu

    一. 基本步骤 1.1 环境准备 开始前,请确认gcc g++开发类库是否装好,默认已经安装. 注: 等待linux下载更新功能准备好了 重启系统 在执行下载安装命令,如执行命令没有问题可以继续往下走 ...

  7. Laravel 程序优化

    转载: Laravel 程序优化 说明 作为优秀的开发者,在日常编码中,应积极培养书写高执行效率代码的意识.不过项目运行效率是一个系统性工程,不应该只停留在代码层面上,有时更应该考虑整个项目架构,包括 ...

  8. 网络架构,七层协议,三次握手四次挥手,socket套接字简单编程

    一.单机架构 应用领域: 植物大战僵尸 office 二.CS架构 应用领域: QQ 大型网络游戏 计算机发展初期用户去取数据,直接就去主机拿,从这里开始就分出了客户端和服务端. 客户端:用户安装的软 ...

  9. 删除项目中所有的__pycache__ 文件

    关于 pycache 当第一次运行 python 脚本时,解释器会将 *.py 脚本进行编译并保存到 __pycache__ 目录 下次执行脚本时,若解释器发现你的 *.py 脚本没有变更,便会跳过编 ...

  10. import cv2 报错:ModuleNotFoundError: No module named 'cv2'

    tensorflow,import cv2报错:ModuleNotFoundError: No module named 'cv2' 我是这样解决的:conda install opencv 然后不报 ...