形形色色Node工程Angular2
最近项目要用的
一些无关紧要的文件夹, demo是一些示例, dist是webpack打包后发布的代码,server是用node启动服务,typings和tsconfig是一些ts配置.
npm install 安装node_modules依赖.
npm start 从package.json指定的webpack.config开始运行.
"start": "concurrently \"webpack --watch --colors\" \"nodemon server/main.js\""
var webpack = require('webpack');
var HtmlWebpackPlugin = require('html-webpack-plugin'); module.exports = {
entry: {
main:['./app/main.ts'],
vendor:[ ]
},
externals:{
"jquery":"jQuery"
},
output: {
path: './dist',
filename: 'js/app.bundle.js',
publicPath:'/'
},
module: {
loaders: [
{test: /\.ts$/, loader: 'ts'},
{test: /\.html$/, loader: 'raw'},
{test: /\.css$/, loader: 'raw'}
]
},
resolve: {
extensions: ['', '.js', '.ts', '.html', '.css']
},
plugins: [
new HtmlWebpackPlugin({
template: './app/index.html'
}),
new webpack.optimize.CommonsChunkPlugin({
name: "vendor",
//filename : 'vendor_[chunkhash].js',
filename : 'js/vendor.js',
minChunks: Infinity
}),
/*new webpack.optimize.UglifyJsPlugin({
compress: {
warnings: false
}
}),*/
new webpack.DefinePlugin({
app: {
environment: JSON.stringify(process.env.APP_ENVIRONMENT || 'development')
}
})
] };
webpack.config
webpack设入口为main.ts
import {platformBrowserDynamic} from '@angular/platform-browser-dynamic';
import {AppModule} from './app.module'; platformBrowserDynamic().bootstrapModule(AppModule);
main.ts导入./app.module.ts(import和require的时候后缀名可以省略)使用bootstrapModule方法启动AppModule
在模块app.module.ts中导入angular基础模块以及自定义组件和路由组件.
import './polyfills'; import {BrowserModule} from "@angular/platform-browser";
import {NgModule} from "@angular/core";
import {HttpModule} from '@angular/http'; // 表单 双向数据绑定
import {AppComponent} from "./app.component";
import { HomeComponent, TestComponent } from './component';
//路由
import APP_ROUTER_PROVIDERS from "./app.routes"; import {enableProdMode} from '@angular/core';
import { LoggerService, GLobalService, UIHelperService } from './service';
enableProdMode(); @NgModule({
imports: [
BrowserModule,
HttpModule,
APP_ROUTER_PROVIDERS
],
declarations: [
AppComponent,
HomeComponent,
TestComponent
],
providers: [
LoggerService,
GLobalService,
UIHelperService
],
bootstrap: [AppComponent]
}) export class AppModule {
}
app.module.ts
自定义组件如果是以页面为划分,比如HomeComponent, TestComponent, 可以在内部再细分功能组件.
例如上面的
import { HomeComponent, TestComponent } from './component';
AppModule中导入页面组件后,在app.routes.ts中作好路由,就可以在html模板中实现页面跳转.
import {RouterModule, Routes } from '@angular/router'; import { HomeComponent, TestComponent } from './component'; const routes = [
{path: '', component: HomeComponent},
{path: 'test', component: TestComponent}
]; export default RouterModule.forRoot(routes);
component.ts中
export * from './app.component' export * from './components/home/home.component'
export * from './components/test/test.component'
统一export组件, Module中统一import或require, 这是这个工程组织的结构.
AppModule最后也是export一个对象供使用.
上面提到的home组件除了home.component.ts还有一个模板文件homecomponent.html.ts
import {Component,OnInit} from "@angular/core";
import { URLSearchParams } from '@angular/http';
import { GLobalService, UIHelperService } from '../../service'; import { htmlTemplate } from './home.component.html'; @Component({
selector: 'home',
template: htmlTemplate
})
export class HomeComponent implements OnInit{
errorMessage:string;
homeData:any; constructor(private _globalService: GLobalService,private _uIHelperService:UIHelperService) {} ngOnInit() {
let requestParams = new URLSearchParams();
requestParams.set('id', '');
this._globalService.ajaxCallerGet(this._globalService.getServiceURL('home'), requestParams).subscribe(
(data) => {
this.homeData=data;
//this._uIHelperService.getTest("test");
console.log(data,this.homeData);
},
error => this.errorMessage = <any>error
);
}
}
hoem.component.ts
其中导入了封装有ajax方法的的service组件, 指定模板文件位置 import { htmlTemplate } from './home.component.html';
export const htmlTemplate = `
<div class="row">{{homeData?.name}}</div>
<a [routerLink]="['/test']">切换到测试页面</a>
`;
中间的a标签插入了路由标志'test', div中的{{插值变量}}语法根据不同的依赖包会有所不同,此处有一个问号?
路由去到test
import {Component} from "@angular/core";
import { htmlTemplate } from './test.component.html';
@Component({
selector: 'test',
styles: [''],
template: htmlTemplate
})
export class TestComponent{
constructor() {
//this.name = 'World';
}
}
读取模板
export const htmlTemplate = `
<div class="row">
我是test
</div>
`;
前台的逻辑基本就是这样,更多有关node的知识以及隐蔽工程有待完善.
形形色色Node工程Angular2的更多相关文章
- 新建node工程
之前各种node工程都是东抄抄,西抄抄的. 用ng的cli之后,发现非常舒服.所以把node新建工程的种种记录一下. node+babel, 直接按es6标准写就好了, 不需要一定写ts再转码了( ...
- 使用pm2-zabbix监控node工程
环境 centos 7 zabbix 3.2.6 node 4.4.3 安装 # wget http://repo.zabbix.com/zabbix/3.2/rhel/7/x86_64/zabbix ...
- 云主机CentOS 7新环境命令行搭建node工程步骤
1.用Node官网提供的命令安装node https://nodejs.org/en/download/package-manager/#debian-and-ubuntu-based-linux-d ...
- node.js + webstorm :配置开发环境
一.配置开发环境: 1.先安装node (1).访问http://nodejs.org打开安装包,正常安装,点击next即可. 为了测试是否安装成功,打开命令提示符,输入node,则进入node.js ...
- node(thrift)
thrift是一种跨语言的RPC框架,据说uber采在node.js项目中采用thrfit后,比原有的http+json的方式提高近20倍的性能. 所谓的RPC本质上就是客户端将需要调用的方法名和参数 ...
- C蛮的全栈之路-node篇(一) 环境布置
目录 C蛮的全栈之路-序章 技术栈选择与全栈工程师C蛮的全栈之路-node篇(一) 环境布置C蛮的全栈之路-node篇(二) 实战一:自动发博客 ---------------- 我是分割线 ---- ...
- node中创建服务进程
背景 在node工程部署中,常常涉及到三方:本地客户端.跳板机和服务器(集群).在通过git触发gitlab hook脚本后,需要在跳板机中执行相应的ssh命令执行shell文件启动node服务器,这 ...
- Node.js C/C++ 插件
插件 Addons 是动态链接的共享对象.他提供了 C/C++ 类库能力.这些API比较复杂,他包以下几个类库: V8 JavaScript, C++ 类库.用来和 JavaScript 交互,比如创 ...
- Node.js小白开路(一)-- 全局变量篇
全局内容是有点类似于我们在浏览器编程的时候的window对象的,当时在node之中虽然我们编写的变量会自动的给出上下文环境(模块),但是全局变量的存在还是大大的帮助了我们编程时候的便捷性.我们可以在任 ...
随机推荐
- flex脚本的申明
//脚本申明的格式 <fx:Script> <![CDATA[ ]]></fx:Script> //程序完成的时候自动调用的事件 cre ...
- iOS开发篇-申请开发者账号流程
1.注册一个苹果的apple id申请apple id的地址: https://appleid.apple.com/account 2.如申请公司账号,请使用以下链接免费获取邓白氏号码,以下的申请表格 ...
- java_一对一自由聊天
客户端 package cn.qianfeng.kaoti03; import java.io.BufferedReader; import java.io.IOException; import j ...
- Java并发——使用Condition线程间通信
线程间通信 线程之间除了同步互斥,还要考虑通信.在Java5之前我们的通信方式为:wait 和 notify.Condition的优势是支持多路等待,即可以定义多个Condition,每个condit ...
- 20160501--struts2入门3
一.自定义拦截器 要自定义拦截器需要实现com.opensymphony.xwork2.interceptor.Interceptor接口: public class PermissionInterc ...
- win 10应用商店下载应用错误码0x80070422
Win10应用商店下载应用提示错误0x80070422怎么办? 一些安装了Win10系统的朋友们在使用过程中发现,在使用WIn8应用商店下载免费应用的时候,系统提示:错误0x80070422,这是怎么 ...
- 华为j2ee面试题
http://blog.csdn.net/chow__zh/article/details/7741312 java基础1.垃圾回收的优点和原理. Java语言中一个显著的特点就是引入了垃圾 ...
- HTML解析引擎:Jumony 开源项目
Jumony Core首先提供了一个近乎完美的HTML解析引擎,其解析结果无限逼近浏览器的解析结果.不论是无结束标签的元素,可选结束标签的元素,或是标记属性,或是CSS选择器和样式,一切合法的,不合法 ...
- ios tableview 上加 textfiled
ios tableview 上加 textfiled 首先附上我项目中用曾经用到的几张图 并说明一下我的用法: 图1: 图2: 图3: 心在你我说一下 我当初的实现 方法 ,希望能给你们一些 启 ...
- 10_Mybatis开发Dao方法——mapper代理实现
[工程截图(几个关键的标红框)] [UserMapper.xml] <?xml version="1.0" encoding="UTF-8"?> & ...