react+tsx+webpack

一、初始化工程

1、创建tsx初始化工程
create-react-app app-demo-ts --scripts-version=react-scripts-ts
2、编写组件类Hello,渲染至页面
3、npm build、npm start,运行正常

二、webpack打包

4、安装webpack,webpack-cli
npm install -g webpack
npm install -g webpack-cli
5、安装ts与webpack整合依赖
npm install --save-dev typescript awesome-typescript-loader source-map-loader
6、webpack执行
报错:TS2307: Cannot find module ‘./logo.svg’
解决:
1)安装 url-loader,file-loader,svg-sprite-loader【最后发现每个都可以】
2)tsconfig.json文件中,增加

  "files": [ 
    "images.d.ts" 
  ]

images.d.ts为项目初始化自带文件

declare module '*.svg'
declare module '*.png'
declare module '*.jpg'
declare module '*.jpeg'
declare module '*.gif'
declare module '*.bmp'
declare module '*.tiff'

3)webpack.config.js文件中,module增加配置

 module: {
        rules: [
            { test: /\.tsx?$/, loader: "awesome-typescript-loader" },
            { enforce: "pre", test: /\.js$/, loader: "source-map-loader" },
            //增加svg文件模块加载器,上面提到的三种loader都可以实现svg文件的加载
            {test:/\.(jpg|png|svg)$/,loader:['file-loader']}
        ]
    }

再次执行webpack命令

WARNING in configuration
The 'mode' option has not been set, webpack will fallback to 'production' for this value. Set 'mode' option to 'development' or 'production' to enable
defaults for each environment.
You can also set it to 'none' to disable any default behavior. Learn more: https://webpack.js.org/concepts/mode/

按照提示,webpack.config.js中增加mode属性

   mode: 'development',

打包成功
react+tsx+webpack_第1张图片
7、引用css文件
1)npm install css-loader style-loader --save-dev
2)加入加载器

{test:/\.css$/,loader:['style-loader','css-loader']}

这里必须注意的是,style-loader与css-loader顺序不能颠倒,否则会打包失败。style-loader 将css插入到页面的style标签,css-loader 是处理css文件中的url()等
3)webpack --display-modules查看打包模块
react+tsx+webpack_第2张图片
打包成功后,页面始终渲染失败
(4)npm run eject
认为是自己配置的原因,于是把隐藏的配置文件给显示出来,执行该反编译操作,可是操作不可逆,想用默认的配置文件,问题不断,于是重新创建项目

三、重新构建

1、create-react-app react_ts --scripts-version=react-scripts-ts
2、npm install --save-dev typescript awesome-typescript-loader source-map-loader
3、npm install css-loader style-loader --save-dev
4、npm install url-loader file-loader svg-sprite-loader
webpack中添加加载器
5、webpack
报错信息

'rootDir' is expected to contain all source files.

修改tsconfig.json,修改rootDir为当前目录
6、npm install -g webpack-dev-server
7、webpack-dev-server

The CLI moved into a separate package: webpack-cli
Please install 'webpack-cli' in addition to webpack itself to use the CLI
-> When using npm: npm i -D webpack-cli
-> When using yarn: yarn add -D webpack-cli
internal/modules/cjs/loader.js:582

8、npm i -D webpack-cli
9、webpack-dev-server --hot --inline
页面仍然渲染不上,查看webpack-dev-server帮助命令,看到了content-base选项,检查了下webpack.config.js,原来是目录设置错了,原本设置的是public目录,可是public下面只有index.html,更改为build目录,刷新页面,页面成功渲染。

备注
在webpack之前,执行npm run build/start命令是可以的,页面也能成功显示;执行webpack之后,在根目录下生成dist目录,执行webpack-dev-server后页面无法成功渲染;回过头来执行npm run build报错,提示budle.js语法有问题。
安装tslint插件,目录下生成tslint.json文件,根据提示逐渐增加配置项后,编译成功。

但是这样岂不是每次编译都把打包后的bundle.js文件包含进去了?是不是可以将webpack打包文件给排除在编译文件之外。

你可能感兴趣的:(框架)