1.项目初始化css
2.提高开发体验html
3.整理项目和杂项node
4.项目打包react
5.团队规范webpack
css-loader
的 css module 功能,并动态生成.scss
的.d.ts
文件由于模板是为之后项目开发所准备的前奏工做,因此在搭建以前我以为首先须要先考虑如下几个方面:ios
前置安装 首先须要全局安装typescript,这里默认你们都已经安装了node以及npm npm install -g typescript
git
首先新建文件夹并进入 mkdir ts-react && cd ts-react
es6
而后进行初始化,生成package.json
和tsconfig.json
npm init -y && tsc --init
github
安装开发工具 这里包含有webpack4, webpack-cli, webpack-dev-server
npm install-D webpack webpack-cli webpack-dev-server
web
安装react相关 由于须要整合ts,而react本来的包是不包含验证包的,因此这里也须要安装相关ts验证宝 npm install -S react react-dom
npm install -D @types/react @types/react-dom
安装ts-loader
(或者awesome-typescript-loader
) 这两款loader用于将ts代码编译成js代码,用法上差别较小,这里选择的是awesome-typescript-loader
npm install -D awesome-typescript-loader
这个时候基本的安装步骤就完成了,之后须要什么再陆续添加进去,如今开始建立项目
webpack配置
在项目根目录新建一个build
文件夹,而后在里面新建webpack.config.js
文件: mkdir build && cd build && touch webpack.config.js
根目录下新建src文件夹,而后在src里新建index.tsx
文件做为项目入口: mkdir src && cd src && touch index.tsx
编写简单的webpack配置,只包含entry
和output
:
编写awesome-typescript-loader
配置项: 在webpack中的module是专门用来决定如何处理各类模块的配置项,例如本例中的typescript,这里主要用的配置项就是module.rules
,而当前只须要简单配置解析.tsx
文件类型便可
在src/index.tsx
中写入口文件
tsconfig
里面没有指定JSX
的版本,这时候在tsconfig
的compilerOptions
中添加"jsx": "react"
配置项便可消除错误 此外还须要注意一点,之后须要import xxx from 'xxx'
这样的文件的话须要在webpack中的resolve
项中配置extensions
,这样之后引入文件就不须要带扩展名
添加页面模板: 在build
文件夹下新建文件夹tpl
,而后在tpl
中新建一个index.html
,以下:
html-webpack-plugin
配置html-webpack-plugin
: 首先咱们安装一下npm install -D html-webpack-plugin
,而后在webpack的plugins配置项下进行一些简单配置:
8 . 配置tsconfig
tsconfig
配置中,会发如今compilerOptions
配置项的target
是es5
,也就是说把ts代码编译成es5规范的代码,若是不作兼容的话,咱们能够将它设置为es6,使其编译成es6的代码module
项中,会发现生成的是commonjs
的模块系统,由于不考虑兼容,因此这里我也将其设定为最新的esnext
,而且将模块处理方式改成用node来处理,设置moduleResolution
项为node
,不作模块处理方式设置的话可能会有报错
9 . 项目启动 这时候咱们能够在package.json
中添加启动命令 "dev": "webpack-dev-server --config build/webpack.config.js --mode development"
, 其中--mode development
用于指定开发模式,不然在webpack4+版本下会有警告 而后直接npm run dev
便可
其实这个时候项目其实就已经跑起来了,彻底能够不用往下看,可是实际上的工做并无作完,下一章就开始讲解如何提升开发体验