快速上手vue3+js+Node.js

安装Navicat Premium

Navicat Premium

创建一个空的文件夹(用于配置node)

生成pakeage.json文件

复制代码
npm init -y

操作mysql

复制代码
npm i mysql@2.18.1

安装express搭建web服务器

复制代码
npm i express@4.17.1

安装cors解决跨域问题

复制代码
npm i cors@2.8.5

创建app.js

复制代码
const express = require('express');
const app = express();
const cors = require('cors');
const bodyParser = require('body-parser');

app.use(cors());
app.use(bodyParser.json());
// 设置静态资源目录
app.use('/static', express.static('E://各类资料//毕业设计'));

// 引入路由文件
const userRouter = require('./user/index');
const homeRouter = require('./home/home');

// 使用路由
app.use('/api', userRouter);
app.use('/api/home', homeRouter);

app.listen(8080, () => {
    console.log("服务器启动 http://127.0.0.1:8080");
});

配置连接mysql--db文件下创建index.js

复制代码
const mysql = require("mysql");

const db = mysql.createConnection({
    host: '127.0.0.1',
    user: 'root',
    password: 'xxxxxx',// 个人数据库密码
    database: 'xxxxxx'// 操作的数据库名
});

db.connect((err) => {
    if (err) {
        console.error('Error connecting to the database:', err.stack);
        return;
    }
    console.log('Connected to the database.');
});

module.exports = db;

user文件夹下创建index.js

复制代码
const express = require("express");
const router = express.Router();
const db = require("../db/index");
const md5 = require("md5");
const multer = require("multer");
const path = require("path");

// 获取用户列表
router.get("/getUserList", (req, res) => {
  const sql = "SELECT * FROM account_info";
  db.query(sql,(err, result) => {
    if (err) { err.message }
    if (result.length < 1) {
      res.send({ status: 1, message: "获取用户列表失败!", code: 400 });
    }
    res.send({ status: 0, data: result, message: "获取用户列表成功", code: 200 });
  });
});

module.exports = router;

注意:其他的crud操作根据实际的需求去操作sql语句来具体实现

创建一个vue的脚手架

在文件夹api下创建request.js文件用于封装axios来发送网络请求

复制代码
import axios from "axios";

// 对 axios 进行二次封装
const requests = axios.create({
    timeout: 5000,
    headers: {
        "Content-Type": "application/json"
    }
});

// 请求拦截器
requests.interceptors.request.use((config) => {
    return config;
}, (error) => {
    return Promise.reject(error);
});

// 响应拦截器
requests.interceptors.response.use((response) => {
    return response.data;
}, (error) => {
    return Promise.reject(error);
});

// 获取
const listUserData = (data) => requests({ url: "http://127.0.0.1:8080/api/getUserList", method: "get", data });

export { listUserData };

node接口效果图

postman

脚手架调用接口返回

UI交互简单实现

相关推荐
王莎莎-MinerU4 小时前
MinerU 深度技术解析:从架构原理到生产部署的全面指南
css·人工智能·自然语言处理·架构·ocr·个人开发
之歆4 小时前
Day19_LESS 完全指南——从入门到工程实践
前端·css·less
不总是5 小时前
Windows 系统 Node.js 免安装版(zip)安装与配置教程(2026 最新)
前端·windows·node.js
吃乔巴的糖9 小时前
Vue 3 打印模板设计器 (print-canvas-designer)
前端·vue.js
蓝乐12 小时前
Express 知识点总结
node.js·express
ZC跨境爬虫13 小时前
跟着 MDN 学CSS day_25:(高级区块效果)
前端·css·html·tensorflow·媒体
如果超人不会飞13 小时前
后端别再手绘了!TinyVue 流程图组件 Flowchart 跨端定制指南
vue.js
cc.ChenLy13 小时前
大文件断点续传原理总结和Demo示例详解
javascript·vue.js·文件上传·大文件断点续传
程序员祥云13 小时前
VUE2_TO_VITE_VUE3
javascript·vue.js·ecmascript
苏瞳儿14 小时前
vue3+pinia+mqtt实时响应连接
前端·javascript·vue.js