搭建Typescript+React项目模板(1) --- 项目初始化

相关文章和阅读顺序

搭建Typescript+React项目模板(1) --- 项目初始化
搭建 Typescript+React 项目模板 (2) --- 提升开发体验
搭建 Typescript+React 项目模板 (3) --- 整理项目和杂项
搭建 Typescript+React 项目模板 (4) --- 项目打包
搭建 Typescript+React 项目模板 (5) --- 团队规范

文章已同步更新到掘金专栏(https://juejin.im/user/5a77c815f265da4e9518bebc/posts)

项目地址

目前集成

需求分析

因为模板是为以后项目开发所准备的前奏工作,所以在搭建之前我觉得首先需要先考虑以下几个方面:

  • 开发体验
  • 项目打包
  • 团队规范
    那么这一篇就先做个起手式,先搭建一个简单的可以跑起来的架子

起手安装

  • 前置安装
    首先需要全局安装typescript,这里默认大家都已经安装了node以及npm
    npm install -g typescript

  • 首先新建文件夹并进入
    mkdir ts-react && cd ts-react

  • 然后进行初始化,生成package.jsontsconfig.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配置
    1. 在项目根目录新建一个build文件夹,然后在里面新建webpack.config.js文件:
      mkdir build && cd build && touch webpack.config.js
    2. 根目录下新建src文件夹,然后在src里新建index.tsx文件作为项目入口:
      mkdir src && cd src && touch index.tsx
    3. 编写简单的webpack配置,只包含entryoutput:
      image.png
    4. 编写awesome-typescript-loader配置项:
      在webpack中的module是专门用来决定如何处理各种模块的配置项,例如本例中的typescript,这里主要用的配置项就是module.rules,而当前只需要简单配置解析.tsx文件类型即可
      image.png
    5. src/index.tsx中写入口文件
      image.png

      但是这时候你会发现有一个错误没有处理
      image.png

      这是因为在tsconfig里面没有指定JSX的版本,这时候在tsconfigcompilerOptions中添加"jsx": "react"配置项即可消除错误
      此外还需要注意一点,以后需要import xxx from 'xxx'这样的文件的话需要在webpack中的resolve项中配置extensions,这样以后引入文件就不需要带扩展名
      image.png
  1. 添加页面模板:
    build文件夹下新建文件夹tpl,然后在tpl中新建一个index.html,如下:

    image.png

    这时候有了页面模板还是不够的,还需要将页面模板和打包出来的js文件关联起来,因为考虑到以后打包出来的js的文件不会是一个固定的名称,所以这里需要使用一个webpack的插件html-webpack-plugin

  2. 配置html-webpack-plugin:
    首先我们安装一下npm install -D html-webpack-plugin,然后在webpack的plugins配置项下进行一些简单配置:

    image.png

    配置完成后就可以启动项目了

8 . 配置tsconfig
- 编译目标
这时候我们切回tsconfig配置中,会发现在compilerOptions配置项的targetes5,也就是说把ts代码编译成es5规范的代码,如果不做兼容的话,我们可以将它设置为es6,使其编译成es6的代码
- 模块处理
module项中,会发现生成的是commonjs的模块系统,因为不考虑兼容,所以这里我也将其设定为最新的esnext,并且将模块处理方式改为用node来处理,设置moduleResolution项为node,不做模块处理方式设置的话可能会有报错

image.png

9 . 项目启动
这时候我们可以在package.json中添加启动命令
"dev": "webpack-dev-server --config build/webpack.config.js --mode development",
其中--mode development用于指定开发模式,否则在webpack4+版本下会有警告
然后直接npm run dev即可

image.png

总结

其实这个时候项目其实就已经跑起来了,完全可以不用往下看,但是实际上的工作并没有做完,下一章就开始讲解如何提高开发体验

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,362评论 5 477
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,330评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,247评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,560评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,580评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,569评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,929评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,587评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,840评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,596评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,678评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,366评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,945评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,929评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,165评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 43,271评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,403评论 2 342

推荐阅读更多精彩内容