angular2环境搭建

Angular2.x与Angular1.x完全不同,Angular2.x是不兼容Angular1.x的,所在在框架的构造上,它们是完全不同的。在Angular2.x中,因为其是基于ES6来开发的,所以会有很多第三方依赖。由于很多浏览器还不支持ES6,所以Angular2引入了很多polyfill或者shim, 导致我们引入了第三方依赖。

官方的说法,它是基于数据流的构建系统(streaming build system),主要用来让自动化和增强你的工作流程(Automate and enhance your workflow)。

1.安装 node v6.x.x      npm 3.x.x    gulp    有兴趣的可以安装typescript

gulp的安装    npm install -g 全局安装环境

gulp 教程:https://www.w3ctech.com/topic/134
中文网:http://www.gulpjs.com.cn/

2.新建项目文件夹(英文)

3.在github上clone相关文件,并放入相关配置项
  地址:https://github.com/Jasonwang911/angular2

4.package.json文件:用来标记项目所需的npm依赖包

这是一个gulp的工作流,在gulp中我们部署的函数都是由gulp.task来执行的,这个文件的主要做的工作是    

1.对angular2源码进行转换,将es6代码转换为es5代码,然后合并成angular2.js,放入dest/lib目录
2.将angular2的第三方依赖放入dest/lib目录
3.自动监测用户写的代码,当文件发生修改时,自动将其编译为es5代码,然后放入dest目录
4.开启一个本地服务器,让用户访问http://localhost:3456/ 就可以看到页面效果
5.删除dest目录

如果想了解gulp可以翻下我之前的博客,或者直接gulp的中文站

‘use strict‘;
var gulp = require(‘gulp‘),
    del = require(‘del‘),
    plumber = require(‘gulp-plumber‘),
    rename = require(‘gulp-rename‘),
    traceur = require(‘gulp-traceur‘);
var connect = require(‘gulp-connect‘),
    open = require(‘gulp-open‘),
    port = 3456;
var PATHS = {
    src: {
        js: ‘src/**/*.js‘,
        html: ‘src/**/*.html‘
    },
    lib: [
        ‘node_modules/gulp-traceur/node_modules/traceur/bin/traceur-runtime.js‘,
        ‘node_modules/es6-module-loader/dist/es6-module-loader-sans-promises.src.js‘,
        ‘node_modules/systemjs/lib/extension-register.js‘,
        ‘node_modules/angular2/node_modules/zone.js/dist/zone.js‘,
        ‘node_modules/angular2/node_modules/zone.js/dist/long-stack-trace-zone.js‘,
        ‘node_modules/reflect-metadata/Reflect.js‘,
        ‘node_modules/reflect-metadata/Reflect.js.map‘,
    ]
};
gulp.task(‘watch‘, function() {
    gulp.watch(PATHS.src.js, [‘js‘]);
    gulp.watch(PATHS.src.html, [‘html‘]);
});
gulp.task(‘js‘, function() {
    return gulp.src(PATHS.src.js)
        .pipe(rename({
            extname: ‘‘
        }))
        .pipe(plumber())
        .pipe(traceur({
            modules: ‘instantiate‘,
            moduleName: true,
            annotations: true,
            types: true,
            memberVariables: true
        }))
        .pipe(rename({
            extname: ‘.js‘
        }))
        .pipe(gulp.dest(‘dist‘));
});
gulp.task(‘html‘, function() {
    return gulp.src(PATHS.src.html)
        .pipe(gulp.dest(‘dist‘));
});
gulp.task(‘angular2‘, function() {
    var buildConfig = {
        paths: {
            "angular2/*": "node_modules/angular2/es6/prod/*.es6",
            "rx": "node_modules/angular2/node_modules/rx/dist/rx.js"
        },
        meta: {
            ‘rx‘: {
                format: ‘cjs‘
            }
        }
    };
    var Builder = require(‘systemjs-builder‘);
    var builder = new Builder(buildConfig);
    return builder.build(‘angular2/angular2‘, ‘dist/lib/angular2.js‘, {});
});
gulp.task(‘libs‘, [‘angular2‘], function() {
    var size = require(‘gulp-size‘);
    return gulp.src(PATHS.lib)
        .pipe(size({
            showFiles: true,
            gzip: true
        }))
        .pipe(gulp.dest(‘dist/lib‘));
});
gulp.task(‘connect‘, function() {
    connect.server({
        root: __dirname + ‘/dist‘,
        port: port,
        livereload: true
    });
});
gulp.task(‘open‘, function() {
    var options = {
        url: ‘http://localhost:‘ + port,
    };
    gulp.src(‘./index.html‘)
        .pipe(open(‘‘, options));
});
gulp.task(‘build‘, [‘js‘, ‘html‘])
gulp.task(‘default‘, [‘build‘, ‘libs‘]);
gulp.task(‘serve‘, [‘connect‘, ‘open‘]);
gulp.task(‘clean‘, function(done) {
    del([‘dist‘], done);
});

5.tyconfig.json文件:定义了typescript编译器如何从项目源文件生成javascript代码

{
  "compilerOptions": {
    "target": "es5",
    "module": "commonjs",
    "moduleResolution": "node",
    "sourceMap": true,
    "emitDecoratorMetadata": true,
    "experimentalDecorators": true,
    "removeComments": false,
    "noImplicitAny": false
  }
}

6.typings.json文件:为那些 TypeScript 编译器无法识别的库提供了额外的定义文件。

{
  "globalDependencies": {
    "core-js": "registry:dt/core-js#0.0.0+20160725163759",
    "jasmine": "registry:dt/jasmine#2.2.0+20160621224255",
    "node": "registry:dt/node#6.0.0+20160909174046"
  }
}

7.systemjs.config.js文件:为模块加载器提供了该到哪里查找应用模块的信息,并注册了所有必备的依赖包。它还包括文档中后面的例子需要用到的包。

8.安装package.json中列出的依赖包,这里需要使用nodejs来定义需要使用的angular2版本和所有第三方依赖的版本

  在node命令行中输入 npm install
  如果运行结束没有生成typings目录,则手动安装 npm run typings install

9.定义该应用的宿主页面,根目录下创建index.html

10.编译并运行应用程序   npm start

你会发现浏览器启动了程序,并且编译了app/app.component.ts文件并输出所有相应的ts文件为js文件,在你编辑文件保存后浏览器会自动刷新并会提示相应的错误

时间: 2024-08-04 04:44:56

angular2环境搭建的相关文章

angular2 环境搭建

angular2 的环境搭建 第一步:到官网下载nodejs 安装包 安装 第二步:安装好了node  会有npm工具 使用 npm 安装 angular cli 命令:  npm install -g @angular/cli    使用ng -v检测 安装好 之后 可以使用   ng new  项目名 命令创建 一个angular的项目 第三步 :  安装webstorm

.Net Core + Angular2 环境搭建

环境搭建: 1)node.js版本>5.0,NPM版本>3.0,TypeScript版本>2.0(全装最新版就好了) 2)安装NTVS 1.2(node tools for vs),TSVS dev 1.4(TS for VS) 3)构建package.json,tsconfig.json,gulp.js文件 1.package.json { "name": "template.angular2", "version": &qu

[Step-By-Step Angular2](1)Hello World与自动化环境搭建

随着rc(release candidate,候选版本)版本的推出,万众瞩目的angular2终于离正式发布不远啦!五月初举办的ng-conf大会已经过去了整整一个月,大多数api都如愿保持在了相对稳定的状态——当然也有router这样的例外,在rc阶段还在大面积返工,让人颇为不解——不过总得说来,现在学习angular2不失为一个恰当的时机. Google为angular2准备了完善的文档和教程,按理说,官网(https://angular.io)自然是学习新框架的最好教材.略显遗憾的是,在B

Angular2 快速入门 之 环境搭建

2015.10.14更新:本文的内容已经过期了,Angular2现在已经完全基于TypeScript开发了,可以移步https://github.com/flyingzl/angular2-seed 查看最新代码. 一.题记 写这篇文章呢,主要是想帮助那些想尝鲜Angular2的童鞋们,因为我自己在玩Angular2时碰到了不少坑,而且Angular2语法一直处于变化中,让人很头疼.不过也怪不了Anguar2,因为它现在是处于并长期处于alpha阶段,本文是基于最新的angular2.0.0-a

Ionic2环境搭建及文件目录介绍

[注]引用自:http://blog.csdn.net/jasonzds/article/details/53821184 1环境搭建 一年前研究混合框架,初步确定了四种方案给公司选择,ionic,hbuilder,wex5,react-native这四个框架各有优缺点,ionic和react-native是国外框架,相对好一点,文档更新很快,就不一一说了,大概的思路都是一样的,js逻辑实现,同时调用原生功能,h5,css3 UI实现,其实他们都有自己的ui框架,当时选择了国内的hbuiler,

AngularJS2学习笔记 ——环境搭建(win7、vs2012)

时代在发展,没有纯粹的后端,想要高工资还是要多学习一个的.不废话了,直奔主题. AngularJS发展到现在已出到AngularJS4了.大致分为AngularJS1.x.AngularJS2.AngularJS4 AngularJS1.x 太久远了,而且从AngularJS2版本开始,与AngularJS1.x是java 与 Javascripte的区别. AngularJS2.0目前主流的,如果想学习就从这个版本开始. AngularJS4 最新版本在2.0基础上把动画效果分离,其它功能的改

一、环境搭建

1 更新到最新版本的pip(这是安装python扩展包的一个插件)命令如下: python -m pip install --upgrade pip 2 使用pip安装virtualenv,命令 pip install virtualenv  如果要指定版本号,pip install virtualenv==15.0.1(安装虚拟环境) 3 创建django虚拟环境,命令 virtualenv django_basic_venv 4 使用虚拟环境 需要进入到安装目录的Scripts文件夹下,运行

Selenium+Java+Eclipse 自动化测试环境搭建

一.下载Java windows java下载链接 https://www.java.com/zh_CN/download/win10.jsp 二.安装Java 安装好后检查一下需不需要配置环境变量,现在java 8已经不用配置环境变量了,直接在命令行输入:java -version 三.下载和安装Eclipse windows Eclipse下载链接 https://www.eclipse.org/downloads/ 你也可以下载绿色版 四.下载selenium,然后解压 selenium

Qt在Mac OS X下的编程环境搭建(配置Qt库和编译器,有图,很清楚)

尊重作者,支持原创,如需转载,请附上原地址:http://blog.csdn.net/libaineu2004/article/details/46234079 在Mac OS X下使用Qt开发,需要配置Qt库和编译器.编译器只能使用苹果公司自主研发的Clang.1.分别下载并安装XCode和Command Line Tools(必须安装),安装完毕后,Clang就有了. https://developer.apple.com/downloads/ 2.下载Qt并默认安装 http://down