首页 技术 正文
技术 2022年11月16日
0 收藏 400 点赞 5,036 浏览 3937 个字

最近项目要用的

形形色色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的知识以及隐蔽工程有待完善.

相关推荐
python开发_常用的python模块及安装方法
adodb:我们领导推荐的数据库连接组件bsddb3:BerkeleyDB的连接组件Cheetah-1.0:我比较喜欢这个版本的cheeta…
日期:2022-11-24 点赞:878 阅读:8,904
Educational Codeforces Round 11 C. Hard Process 二分
C. Hard Process题目连接:http://www.codeforces.com/contest/660/problem/CDes…
日期:2022-11-24 点赞:807 阅读:5,430
下载Ubuntn 17.04 内核源代码
zengkefu@server1:/usr/src$ uname -aLinux server1 4.10.0-19-generic #21…
日期:2022-11-24 点赞:569 阅读:6,247
可用Active Desktop Calendar V7.86 注册码序列号
可用Active Desktop Calendar V7.86 注册码序列号Name: www.greendown.cn Code: &nb…
日期:2022-11-24 点赞:733 阅读:6,058
Android调用系统相机、自定义相机、处理大图片
Android调用系统相机和自定义相机实例本博文主要是介绍了android上使用相机进行拍照并显示的两种方式,并且由于涉及到要把拍到的照片显…
日期:2022-11-24 点赞:512 阅读:7,690
Struts的使用
一、Struts2的获取  Struts的官方网站为:http://struts.apache.org/  下载完Struts2的jar包,…
日期:2022-11-24 点赞:671 阅读:4,727