從零開始用react + tailwindcs + express + mongodb實現一個聊天程序(一)

?項目包含5個模塊

1.首頁 (聊天主頁)

2.注冊

3.登錄

4.個人資料

5.設置主題

一、配置開發環境 建立項目文件夾

mkdir chat-project
cd chat-project
mkdir server && mkdir webcd server npm init
cd web npm create vite@latest

? ?創建前端項目時我們選擇javascript (typescript不熟)

? ?根據提示提示 enter 創建后端 前后端2個項目? 把文件夾整理成如下所示

? ? ? ? ??

二、安裝依賴

1.server端

npm i bcryptjs cloudinary cookie-parser cors dotenv express jsonwebtoken mongoose socket.ionpm i nodemon -D

? ? ?最終package.json如下圖

2.web端

代碼如下(示例):

npm i axios lucide-react react-hot-toast react-router-dom socket.io-client zustand
npm i tailwindcss@3.4.17 postcss autoprefixer daisyui -D

1.配置tailwindcss

在web 文件夾下執行 npx tailwindcss init

tailwind.config.js 內容如下

/** @type {import('tailwindcss').Config} */
import daisyui from "daisyui"
export default  {content: ["./src/**/*.{html,js,jsx,ts,tsx}"],theme: {extend: {},},plugins: [daisyui],daisyui: {themes:["light","dark","cupcake","bumblebee","emerald","corporate","synthwave","retro","cyberpunk","valentine","halloween","garden","forest","aqua","lofi","pastel","fantasy","wireframe","black","luxury","dracula","cmyk","autumn","business","acid","lemonade","night","coffee","winter","dim","nord","sunset",]},
}

vite.config.js配置情況

import { defineConfig } from 'vite'
import react from '@vitejs/plugin-react'
import path from 'path'
import tailwindcss from "tailwindcss"// https://vite.dev/config/
export default defineConfig({plugins: [react()],resolve: {alias: {'@': path.resolve(__dirname, './src')}},// 新增 css 配置css: {postcss: {plugins: [tailwindcss()],}}
})

新建index.css文件? 并在main.jsx下引入 index.css內容

@tailwind base;

@tailwind components;

@tailwind utilities;

?最終前端項目文件結構如下


?3.測試依賴安裝

把原有的App.jsx內容刪除? 替換為

import { useState } from 'react'
function App() {return (<><button className="btn">Button</button><button className="btn btn-neutral">Neutral</button><button className="btn btn-primary">Primary</button><button className="btn btn-secondary">Secondary</button><button className="btn btn-accent">Accent</button><button className="btn btn-ghost">Ghost</button><button className="btn btn-link">Link</button><h1 className='text-blue-500'>測試內容</h1></>)
}export default App

在web目錄下執行 npm run dev 得到如下效果?

以上就是今天要講的內容,本文僅僅簡單介紹了文件目錄的創建 前后臺依賴的安裝。如有問題請留言。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/896154.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/896154.shtml
英文地址,請注明出處:http://en.pswp.cn/news/896154.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

深入理解 QObject的作用

QObject 作為 Qt 庫中所有對象的基類&#xff0c;其地位無可替代。幾乎 Qt 框架內的每一個類&#xff0c;無論是負責構建用戶界面的 QWidget&#xff0c;還是專注于數據處理與呈現的 QAbstractItemModel&#xff0c;均直接或間接繼承自 QObject。這種繼承體系賦予 Qt 類庫高度的…

22爬蟲:使用Drission Page的兩個案例

案例一&#xff1a;使用DrissionPage抓取BOSS上的招聘信息 使用requests獲取BOSS網站上的內容是非常困難的&#xff0c;但是通過網頁自動化工具DrissionPage或者是Playwright或者是Seleenium是非常容易的&#xff0c;接下來我們就給出使用DrissionPage爬取BOSS網站python招聘的…

Ubuntu 下 nginx-1.24.0 源碼分析 - ngx_atoi 函數

ngx_atoi 聲明在 src/core/ngx_string.h ngx_int_t ngx_atoi(u_char *line, size_t n); 定義在 src/core/ngx_string.c ngx_int_t ngx_atoi(u_char *line, size_t n) {ngx_int_t value, cutoff, cutlim;if (n 0) {return NGX_ERROR;}cutoff NGX_MAX_INT_T_VALUE / 10;cutlim…

具有整合各亞專科醫學領域知識能力的AI智能體開發綱要(2025版)

整合各亞專科醫學領域知識能力的AI代理的開發與研究 一、引言 1.1 研究背景 在科技飛速發展的當下,人工智能(AI)已成為推動各行業變革的關鍵力量,醫療領域也不例外。近年來,AI 在醫療行業的應用取得了顯著進展,從醫學影像診斷到疾病預測,從藥物研發到個性化醫療,AI 技…

如何設計app測試用例

功能測試 測試方法&#xff1a;等價類劃分法、邊界值法、場景法、因果圖法。優先級設定&#xff1a;核心業務功能設為高優先級。需求覆蓋 正向場景、反向場景、關聯接口串場景 與后端開發確認測試用例是否全面覆蓋后端邏輯。和產品確認用例是否覆蓋本次需求&#xff0c;以及是否…

YOLO11 【四】 【DNF制作自己的數據集,切割視頻以及labelimg 閃退問題】

一、問題labelimg 閃退 一點w打標 labelimg就閃退 **原因 &#xff1a; python 版本太高 ** 解決辦法&#xff1a;單獨創建一個虛擬環境用于打標 conda create -n labelimg python3.9 二、使用python腳本切割視頻 # -*- coding: utf-8 -*- import cv2 import osdef video_…

[MDM 2024]Spatial-Temporal Large Language Model for Traffic Prediction

論文網址&#xff1a;[2401.10134] Spatial-Temporal Large Language Model for Traffic Prediction 論文代碼&#xff1a;GitHub - ChenxiLiu-HNU/ST-LLM: Official implementation of the paper "Spatial-Temporal Large Language Model for Traffic Prediction" …

k2路由器登錄校園網

教程1刷入Breed&#xff0c;并手動刷入Padavan固件&#xff1a;斐訊K1、K2、K2P 刷機、刷入Breed 輔助工具 | tb (tbvv.net) Padavan下載網址&#xff1a; 我用的是&#xff1a; Padavan 登錄的網址是 192.168.123.1 Padavan配置教程&#xff1a; 先用網線連上校園網&#…

多源 BFS 算法詳解:從原理到實現,高效解決多源最短路問題

多源 BFS 是一種解決 邊權為 1 的多源最短路問題 的高效算法。其核心思想是將所有源點視為一個“超級源點”&#xff0c;通過一次 BFS 遍歷即可計算所有節點到最近源點的最短距離。以下從原理、實現和代碼示例三個方面深入講解&#xff1a; 目錄 一、原理分析 1. 單源 BFS vs…

【藍橋杯集訓·每日一題2025】 AcWing 6123. 哞叫時間 python

6123. 哞叫時間 Week 1 2月18日 農夫約翰正在試圖向埃爾茜描述他最喜歡的 USACO 競賽&#xff0c;但她很難理解為什么他這么喜歡它。 他說「競賽中我最喜歡的部分是貝茜說 『現在是哞哞時間』并在整個競賽中一直哞哞叫」。 埃爾茜仍然不理解&#xff0c;所以農夫約翰將競賽以…

C++,設計模式,【工廠方法模式】

文章目錄 如何用汽車生產線理解工廠方法模式?一、傳統生產方式的困境二、工廠方法模式解決方案三、模式應用場景四、模式優勢分析五、現實應用啟示?C++,設計模式,【目錄篇】 如何用汽車生產線理解工廠方法模式? 某個早晨,某車企CEO看著會議室里堆積如面的新車訂單皺起眉…

貪心算法

int a[1000], b5, c8; swap(b, c); // 交換操作 memset(a, 0, sizeof(a)); // 初始化為0或-1 引導問題 為一個小老鼠準備了M磅的貓糧&#xff0c;準備去和看守倉庫的貓做交易&#xff0c;因為倉庫里有小老鼠喜歡吃的五香豆&#xff0c;第i個房間有J[i] 磅的五香豆&#xf…

機器學習·數據處理

前言 對于大規模數據&#xff0c;我們經常會使用python內置函數或者編寫腳本進行批量化處理&#xff0c;從而提高后續使用算法的效率。 1. 正則表達式 定義&#xff1a;用于檢索、替換符合某個模式的文本&#xff0c;是文本預處理常用技術。基本語法 符號描述.匹配除換行符 …

大廠出品!三個新的 DeepSeek 平替網站

前幾天給大家分享了幾個 DeepSeek 免費平替網站&#xff0c;今天又來更新啦。 新增了以下三個平臺&#xff1a;火山引擎、知乎直達、百度搜索。 經過實際測試&#xff0c;這幾個平臺的服務響應速度快&#xff0c;穩定性表現優異&#xff0c;基本不會出現宕機或服務器繁忙的情…

[創業之路-321]:創新開拓思維和經營管理思維的比較

目錄 一、概述 1.1、定義與內涵 1、創新開拓思維&#xff1a; 2、經營管理思維&#xff1a; 1.2、特點與優勢 1、創新開拓思維的特點與優勢&#xff1a; 2、經營管理思維的特點與優勢&#xff1a; 3、應用場景與限制 4、總結 二、創新開拓思維與經營管理思維&#xf…

《深度學習實戰》第1集:深度學習基礎回顧與框架選擇

本專欄系列博文旨在幫助讀者從深度學習的基礎知識逐步進階到前沿技術&#xff0c;涵蓋理論、實戰和行業應用。每集聚焦一個核心知識點&#xff0c;并結合實際項目進行實踐&#xff0c;避免空談理論&#xff0c;簡潔明快&#xff0c;快速切入代碼&#xff0c;所有代碼都經過驗證…

經典復古嘻哈說唱朋克風格專輯海報標題設計psai英文字體安裝包 Punk Of Sad — Ransom Font

Punk Of Sad 將確保您忘記所有簡潔的線條和企業潤色。這種經典的贖金風格字體是一封寫給 DIY 文化的情書&#xff0c;誕生于雜志、演出海報和地下場景的原始能量的剪切和粘貼混亂。每個字母都是不可預測的&#xff0c;都帶有叛逆的邊緣。 這種字體有三種不同的樣式 – Regular…

hot100-滑動窗口

3. 無重復字符的最長子串 給定一個字符串 s &#xff0c;請你找出其中不含有重復字符的 最長子串的長度。 思路&#xff1a;雙指針指向不含重復字符的連續字串的頭和尾&#xff0c;用集合存儲子串中的元素&#xff0c;有重復時&#xff0c;左指針持續右移&#xff0c;無重復后…

MariaDB 歷史版本下載地址 —— 筑夢之路

MariaDB 官方yum源里面只有目前在維護的版本&#xff0c;而有時候對于老項目來說還是需要老版本的rpm包&#xff0c;國內很多鏡像站都是同步的官方倉庫&#xff0c;因此下載老版本也不好找&#xff0c;這里主要記錄下從哪里可以下載到歷史版本的MariaDB rpm包。 1. 官方歸檔網…

Linux-Ansible模塊進階

文章目錄 Copy和FetchFile模塊 Copy和Fetch copy和fetch模塊實踐 copy模塊需要注意的點&#xff1a;在收集日志之前需要對文件先進行改名或者備份fetch模塊需要注意的點&#xff1a;復制的源文件的路徑必須是文件不能是目錄建議全部使用絕對路徑&#xff0c;別使用相對路徑確保…