详解webpack+angular2开发环境搭建


Posted in Javascript onJune 28, 2017

刚搭建完一个webpack+angular2环境,由于angular及webpack官网上没有一个折中的搭建方案,所以只能摸索着搭建,中间遇到一些坑,遂总结记录下来,以供交流。

搭建完后的项目初步环境如下:

app
----app.component.ts
----app.module.ts
----main.ts
index.html
package.json
tsconfig.json
webpack.config.js

app.componnet.ts:组件文件。angular2应用是由组件构成,组件控制视图;

import { Component } from '@angular/core';
@Component({
 selector: 'my-app',
 template: `
  <h1>{{title}}</h1>
  <h2>My favorite hero is: {{myHero}}</h2>
  `
})
// 使用变量初始化方式
export class AppComponent {
 title = 'Tour of Heroes';
 myHero = 'Windstorm';
}

app.module.ts:应用跟模块。angular是模块化,拥有自己的模块系统,被称为angular模块或NgModules(深入了解);//缺少下述模块引入,会输出"Uncaught reflect-metadata shim is required when using class decorators"的错误

import 'core-js/es6';
import 'core-js/es7/reflect';
import 'zone.js/dist/zone';
//引入NgModule装饰器
import { NgModule }   from '@angular/core';
//引入浏览器模块
import { BrowserModule } from '@angular/platform-browser';
//引入创建的component
import { AppComponent } from './app.component';


@NgModule({
 imports:   [ BrowserModule ],
 declarations: [ AppComponent ],
 bootstrap:  [ AppComponent ]
})
export class AppModule { }

 main.ts:用于引导跟模块启动应用;

import { platformBrowserDynamic } from '@angular/platform-browser-dynamic';
 import { AppModule }       from './app.module';
 //引导跟模块启动应用
platformBrowserDynamic().bootstrapModule(AppModule);

index.html:angular应用宿主页面;
<!DOCTYPE HTML>
<html lang="zh-CN">
<head>
  <meta charset="UTF-8" />
  <meta name="viewport" content="width=device-width" />
  <title>small胖的博客</title>
</head>
<body>
  <my-app></my-app>
  <script src="dist/bundle.js"></script>
</body>
</html>

package.json:一个标准化的npm说明文件,其中包含诸如当前应用的依赖包、自定义的脚本命令等,在cmd终端可用npm init自动创建该文件;

注意,此处如果引入的angular模块版本是2.4.X,则会报错“Angular2 + Jspm.io : reflect-metadata shim is required when using class decorators”,产生此坑的具体原因尚不清楚,希望有朋友一起交流。

{
 "name": "blogcode",
 "version": "1.0.0",
 "description": "",
 "main": "webpack.config.js",
 "dependencies": {
  "ts-loader": "2.0.0",
  "@angular/common": "2.1.2",
  "@angular/compiler": "2.1.2",
  "@angular/core": "2.1.2",
  "@angular/platform-browser": "2.1.2",
  "@angular/platform-browser-dynamic":"2.1.2",
  "rxjs": "5.0.0-beta.12",
  "zone.js": "0.6.26",
  "core-js": "^2.4.1"
 },
 "devDependencies": {
  "webpack": "^2.2.1",
  "@types/core-js": "^0.9.35",
  "typescript": "^2.1.5",
  "webpack": "^2.2.0",
  "webpack-dev-server": "^2.3.0"
 },
 "scripts": {
  "test": "echo \"Error: no test specified\" && exit 1"
 },
 "repository": {
  "type": "git",
  "url": "https://git.coding.net/frankshin/xudengwei.git"
 },
 "author": "",
 "license": "ISC"
}

tsconfig.json:用于定义typescript编译成ES5的各项参数;

{
  "compilerOptions": {
    "module": "commonjs",
    "target": "es5",
    "moduleResolution": "node",
    "noImplicitAny": true,
    "removeComments": true,
    "emitDecoratorMetadata": true,
    "experimentalDecorators": true,
    "sourceMap": true,
    "declaration": false
  },
  "buildOnSave": false,
  "compileOnSave": false,
  "exclude": [
    "node_modules"
  ]
}

webpack.config.js:一个标准化的commonjs文件,用于配置webpack编译打包的参数。

module.exports = {
  entry: "./app/main.ts",
  output: {
    path: __dirname + '/dist',
    filename: "bundle.js"
  },
  module: {
  rules: [
    {
     test: /\.tsx?$/,
     loader: 'ts-loader',
     exclude: /node_modules/,
    },
  ]
  },
  resolve: {
   extensions: [".tsx", ".ts", ".js"]
  }
};

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
jQuery 1.0.4 - New Wave Javascript(js源文件)
Jan 15 Javascript
Jquery实现地铁线路指示灯提示牌效果的方法
Mar 02 Javascript
详解JavaScript中数组和字符串的lastIndexOf()方法使用
Mar 13 Javascript
JavaScript图像延迟加载库Echo.js
Apr 05 Javascript
Vue.js 2.0 和 React、Augular等其他前端框架大比拼
Oct 08 Javascript
解决给dom元素绑定click等事件无效问题的方法
Feb 17 Javascript
node+vue实现用户注册和头像上传的实例代码
Jul 20 Javascript
JavaScript中的一些隐式转换和总结(推荐)
Dec 22 Javascript
weui中的picker使用js进行动态绑定数据问题
Nov 06 Javascript
js实现文章目录索引导航(table of content)
May 10 Javascript
解决vue项目获取dom元素宽高总是不准确问题
Jul 29 Javascript
JS JQuery获取data-*属性值方法解析
Sep 01 jQuery
JavaScript中最常用的10种代码简写技巧总结
Jun 28 #Javascript
AngularJS页面带参跳转及参数解析操作示例
Jun 28 #Javascript
AngularJS基于provider实现全局变量的读取和赋值方法
Jun 28 #Javascript
JavaScript循环_动力节点Java学院整理
Jun 28 #Javascript
JavaScript方法_动力节点Java学院整理
Jun 28 #Javascript
微信小程序后台解密用户数据实例详解
Jun 28 #Javascript
JavaScript箭头函数_动力节点Java学院整理
Jun 28 #Javascript
You might like
PHP 类相关函数的使用详解
2013/05/10 PHP
php日历制作代码分享
2014/01/20 PHP
php跨域cookie共享使用方法
2014/02/20 PHP
php读取txt文件并将数据插入到数据库
2016/02/23 PHP
PHP使用PHPExcel删除Excel单元格指定列的方法
2016/07/06 PHP
php魔法函数与魔法常量使用介绍
2017/07/23 PHP
使用VS开发 Node.js指南
2015/01/06 Javascript
js仿微博实现统计字符和本地存储功能
2015/12/22 Javascript
JavaScript的模块化开发框架Sea.js上手指南
2016/05/12 Javascript
详解vue-resource promise兼容性问题
2017/06/20 Javascript
JavaScript实现旋转轮播图
2020/08/18 Javascript
在React 组件中使用Echarts的示例代码
2017/11/08 Javascript
JavaScript实现二叉树定义、遍历及查找的方法详解
2017/12/20 Javascript
解决vue中无法动态修改jqgrid组件 url地址的问题
2018/03/01 Javascript
nodejs中函数的调用实例详解
2018/10/31 NodeJs
[01:14]2014DOTA2展望TI 剑指西雅图newbee战队专访
2014/06/30 DOTA
[01:04:09]DOTA2-DPC中国联赛 正赛 iG vs VG BO3 第二场 2月2日
2021/03/11 DOTA
浅谈python可视化包Bokeh
2018/02/07 Python
浅析python3中的os.path.dirname(__file__)的使用
2018/08/30 Python
Python实现FM算法解析
2019/06/18 Python
Python time库基本使用方法分析
2019/12/13 Python
Python搭建HTTP服务过程图解
2019/12/14 Python
使用opencv中匹配点对的坐标提取方式
2020/06/04 Python
Python3爬虫关于代理池的维护详解
2020/07/30 Python
超酷炫 CSS3垂直手风琴菜单
2016/06/28 HTML / CSS
Html5实现文件异步上传功能
2017/05/19 HTML / CSS
通过canvas转换颜色为RGBA格式及性能问题的解决
2019/11/22 HTML / CSS
The Hut德国站点:时装、家居用品、美容等
2016/09/23 全球购物
Boden英国官网:英国知名原创时装品牌
2018/11/06 全球购物
波兰运动鞋网上商店:Distance.pl
2020/07/30 全球购物
园林技术个人的自我评价
2014/01/08 职场文书
物流毕业生个人的自我评价
2014/02/13 职场文书
学习全国两会精神心得体会范文
2014/03/17 职场文书
社团活动总结范文
2014/04/26 职场文书
pycharm部署django项目到云服务器的详细流程
2021/06/29 Python
Win11绿屏怎么办?Win11绿屏死机的解决方法
2021/11/21 数码科技