内容简介:因为模板是为以后项目开发所准备的前奏工作,所以在搭建之前我觉得首先需要先考虑以下几个方面:这个时候基本的安装步骤就完成了,以后需要什么再陆续添加进去,现在开始创建项目其实这个时候项目其实就已经跑起来了,完全可以不用往下看,但是实际上的工作并没有做完,下一章就开始讲解如何提高开发体验
因为模板是为以后项目开发所准备的前奏工作,所以在搭建之前我觉得首先需要先考虑以下几个方面:
- 开发体验
- 项目打包
- 团队规范 那么这一篇就先做个起手式,先搭建一个简单的可以跑起来的架子
起手安装
-
前置安装 首先需要全局安装typescript,这里默认大家都已经安装了node以及npm
npm install -g typescript
-
首先新建文件夹并进入
mkdir ts-react && cd ts-react
-
然后进行初始化,生成
package.json
和tsconfig.json
npm init -y && tsc --init
-
安装开发 工具 这里包含有
webpack4, webpack-cli, webpack-dev-server
npm install-D webpack webpack-cli webpack-dev-server
-
安装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
即可 -
总结
其实这个时候项目其实就已经跑起来了,完全可以不用往下看,但是实际上的工作并没有做完,下一章就开始讲解如何提高开发体验
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网
猜你喜欢:- 初始化 Emberjs 项目
- hapi框架搭建记录(一):初始化项目
- 会vue就会angular 6 - 项目初始化
- 好用的项目初始化工具 SCION 升级啦!
- Net开源框架ABP初探(一)— 项目初始化
- golang安装遇到问题和解决,初始化beego项目
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
深入浅出WebAssembly
于航 / 电子工业出版社 / 2018-11 / 128.00元
WebAssembly是一种新的二进制格式,它可以方便地将C/C++等静态语言的代码快速地“运行”在浏览器中,这一特性为前端密集计算场景提供了无限可能。不仅如此,通过WebAssembly技术,我们还可以将基于Unity等游戏引擎开发的大型游戏快速地移植到Web端。WebAssembly技术现在已经被计划设计成W3C的标准,众多浏览器厂商已经提供了对其MVP版本标准的支持。在Google I/O ......一起来看看 《深入浅出WebAssembly》 这本书的介绍吧!