详解webpack+angular2开发环境搭建
发布时间 - 2026-01-11 02:05:53 点击率:次刚搭建完一个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"]
}
};
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
# webpack搭建angular2
# webpack
# angular2
# windows下vue-cli及webpack搭建安装环境
# vue+node+webpack环境搭建教程
# webpack vue项目开发环境局域网访问方法
# 详解Webpack + ES6 最新环境搭建与配置
# 浅谈Webpack下多环境配置的思路
# webpack本地开发环境无法用IP访问的解决方法
# react.js使用webpack搭配环境的入门教程
# Webpack设置环境变量的一些误区详解
# 自己的
# 是由
# 自定义
# 被称为
# 报错
# 则会
# 完后
# 该文件
# 朋友一起
# 官网
# 大家多多
# 以供
# 尚不
# 其中包含
# 编译成
# 博客
# bootstrap
# AppModule
# imports
# declarations
相关栏目:
【
网站优化151355 】
【
网络推广146373 】
【
网络技术251813 】
【
AI营销90571 】
相关推荐:
Python面向对象测试方法_mock解析【教程】
Laravel广播系统如何实现实时通信_Laravel Reverb与WebSockets实战教程
Laravel用户认证怎么做_Laravel Breeze脚手架快速实现登录注册功能
怎么制作网站设计模板图片,有电商商品详情页面的免费模板素材网站推荐吗?
Laravel Seeder填充数据教程_Laravel模型工厂Factory使用
如何快速搭建高效WAP手机网站吸引移动用户?
Laravel如何使用缓存系统提升性能_Laravel缓存驱动和应用优化方案
如何在腾讯云免费申请建站?
Microsoft Edge如何解决网页加载问题 Edge浏览器加载问题修复
javascript日期怎么处理_如何格式化输出
如何快速搭建支持数据库操作的智能建站平台?
如何在Ubuntu系统下快速搭建WordPress个人网站?
如何用花生壳三步快速搭建专属网站?
小米17系列还有一款新机?主打6.9英寸大直屏和旗舰级影像
Laravel如何实现本地化和多语言支持_Laravel多语言配置与翻译文件管理
iOS UIView常见属性方法小结
昵图网官网入口 昵图网素材平台官方入口
动图在线制作网站有哪些,滑动动图图集怎么做?
,怎么在广州志愿者网站注册?
Swift开发中switch语句值绑定模式
UC浏览器如何切换小说阅读源_UC浏览器阅读源切换【方法】
使用豆包 AI 辅助进行简单网页 HTML 结构设计
Win11怎么关闭透明效果_Windows11辅助功能视觉效果设置
php8.4header发送头信息失败怎么办_php8.4header函数问题解决【解答】
php读取心率传感器数据怎么弄_php获取max30100的心率值【指南】
Laravel如何集成微信支付SDK_Laravel使用yansongda-pay实现扫码支付【实战】
音乐网站服务器如何优化API响应速度?
极客网站有哪些,DoNews、36氪、爱范儿、虎嗅、雷锋网、极客公园这些互联网媒体网站有什么差异?
如何在IIS中配置站点IP、端口及主机头?
如何在Windows 2008云服务器安全搭建网站?
Laravel如何使用Livewire构建动态组件?(入门代码)
如何在 Python 中将列表项按字母顺序编号(a.、b.、c. …)
WordPress 子目录安装中正确处理脚本路径的完整指南
IOS倒计时设置UIButton标题title的抖动问题
家族网站制作贴纸教程视频,用豆子做粘帖画怎么制作?
大学网站设计制作软件有哪些,如何将网站制作成自己app?
儿童网站界面设计图片,中国少年儿童教育网站-怎么去注册?
Laravel任务队列怎么用_Laravel Queues异步处理任务提升应用性能
ChatGPT怎么生成Excel公式_ChatGPT公式生成方法【指南】
如何在 React 中条件性地遍历数组并渲染元素
Laravel如何使用Scope本地作用域_Laravel模型常用查询逻辑封装技巧【手册】
如何快速生成ASP一键建站模板并优化安全性?
宙斯浏览器文件分类查看教程 快速筛选视频文档与图片方法
非常酷的网站设计制作软件,酷培ai教育官方网站?
EditPlus中的正则表达式实战(6)
通义万相免费版怎么用_通义万相免费版使用方法详细指南【教程】
大同网页,大同瑞慈医院官网?
Laravel如何发送系统通知_Laravel Notifications实现多渠道消息通知
如何在香港服务器上快速搭建免备案网站?
python中快速进行多个字符替换的方法小结

