IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> 搭建react-typescript-webpack开发环境 -> 正文阅读

[JavaScript知识库]搭建react-typescript-webpack开发环境

环境

  • vscode
  • mac
  • react 18
  • webpack
  • typescript
  • npm

一、开发环境搭建

vscode搭建react-typescript-webpack

1. 创建项目文件夹及webpack配置文件、html入口文件

mkdir react-ts-webpack-demo
cd react-ts-webpack-demo
touch webpack.config.js index.html

2. 初始化npm和创建入口文件index.tsx

npm init -y
  • 生成最小粒度的package.json配置文件,之后使用npm安装的依赖包都会放在package.json文件中。
  • 创建src文件夹将入口文件index.tsx放进去,此时项目结构如下所示:
    在这里插入图片描述

3. 安装webpack\react

npm i webpack webpack-cli webpack-dev-server -D
npm i react react-dom -S

此时的packages.json文件自动配置安装的五个依赖包
在这里插入图片描述

4. 配置webpack.config.js

(1)安装html-webpack-plugin、clean-webpack-plugin、awesome-typescript-loader、typescript

npm i html-webpack-plugin --dev
npm i clean-webpack-plugin -S
npm i typescript ts-loader -D
const path = require("path");
const HtmlWebpackPlugin = require("html-webpack-plugin");
const { CleanWebpackPlugin } = require("clean-webpack-plugin");

module.exports = {
  mode: "development", //指定开发模式,默认为none
  entry: "./src/index.tsx", //入口文件
  output: {
    path: path.resolve(__dirname, "dist"), //指定输出文件存放到dist文件夹中
    filename: "bundle.js", //指定打包后生成的文件名称为bundle.js
  },
  module: {
    rules: [
      {
        test: /\.tsx?$/, // 由awesome-typescript-loader 解析以.tsx结尾的文件
        loader: "ts-loader", 
        exclude: /node_modules/,
      },
    ],
  },
  resolve: {
    extensions: [".tsx", ".ts", ".js"], //定义解析文件的顺序,且引入这些文件可以不加后缀
  },
  plugins: [
    //指定加载的index.html
    new HtmlWebpackPlugin({
      template: path.resolve(__dirname, "index.html"),
    }),
    // 每次打包都自动删掉上一次打包留下的包(dist)
    new CleanWebpackPlugin({}),
  ],
};

5. 创建和配置tsconfig.json文件

添加 tsconfig.json 文件,告诉 webpack 去哪儿寻找 typescript 文件以及编译选项配置,配置内容如下所示:

{
  "compilerOptions": {
    "outDir": "./dist/",
    "noImplicitAny": true,
    "module": "es6",
    "target": "es5",
    "jsx": "react",
    "allowJs": true,
    "moduleResolution": "node"
  }
}

6. 安装@react文件

使用@types/前缀表示我们额外要获取 React 和 React-DOM 的声明文件

npm i @types/react @types/react-dom -D

7. 到package.json修改启动项目的方式

 "scripts": {
    "test": "echo \"Error: no test specified\" && exit 1",
    "serve": "webpack-dev-server",
    "build": "webpack"
  },

现在可以使用npm run serve启动项目,npm run build打包项目,打开之后是空白页面,因为还没有加入DOM元素对页面进行渲染。
目录结构如下所示:
在这里插入代码片
packages.json文件如下所示:

{
  "name": "react-ts-webpack-demo",
  "version": "1.0.0",
  "description": "",
  "main": "webpack.config.js",
  "scripts": {
    "test": "echo \"Error: no test specified\" && exit 1",
    "serve": "webpack-dev-server",
    "build": "webpack"
  },
  "keywords": [],
  "author": "",
  "license": "ISC",
  "dependencies": {
    "clean-webpack-plugin": "^4.0.0",
    "react": "^18.2.0",
    "react-dom": "^18.2.0",
    "react-scripts": "^5.0.1"
  },
  "devDependencies": {
    "@types/react": "^18.0.14",
    "@types/react-dom": "^18.0.5",
    "html-webpack-plugin": "^5.5.0",
    "ts-loader": "^9.3.1",
    "typescript": "^4.7.4",
    "webpack": "^5.73.0",
    "webpack-cli": "^4.10.0",
    "webpack-dev-server": "^4.9.2"
  }
}

ps:以上步骤参照文章:https://zhuanlan.zhihu.com/p/59023070,但是做的过程中发现页面渲染部分有问题,所以在文章的基础上重新做了改进。

8. 配置index.html 、入口文件index.tsx

index.html

在body标签里面创建一个id为root的div,方便入口文件获取

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    // 将项目标题改为从htmlwebpackplugin中动态获取
    <title><%= htmlWebpackPlugin.options.title %></title>
</head>
<body>
    <div id="root"></div>
</body>
</html>

使用createReact获取根元素root后将DOM渲染到该根元素下面:

import * as React from "react";
import { createRoot } from "react-dom/client";

const root = createRoot(document.getElementById("root"));
root.render(<h1>Hello world!</h1>);

react 18 用createRoot取代React17 的render函数去渲染DOM元素,开发的时候遇到了DOM没有渲染出来的问题,可以参考附录的开发过程记录文章区解决。

// 持续更新中。。。

附录

开发过程错误记录

  1. react 18 createRoot没有渲染出DOM元素
  2. 运行时出现Uncaught ReferenceError: process is not defined错误提示
  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2022-07-04 22:45:33  更:2022-07-04 22:47:02 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/11 10:58:54-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码