当前位置: 首页 > article >正文

快速上手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交互简单实现


http://www.kler.cn/a/384138.html

相关文章:

  • Docker基本概念汇总(更全面了解Docker)
  • 自动驾驶革命:从特斯拉到百度,谁将主宰未来交通?
  • 《AI在企业战略中的关键地位:以微软和阿里为例》
  • 这款神器,运维绝杀 !!!
  • C语言必做30道练习题
  • 基于梧桐数据库的实时数据分析解决方案
  • 实践出真知:MVEL表达式empty的坑
  • vue中html如何转成pdf下载,pdf转base64,忽略某个元素渲染在pdf中,方法封装
  • 【Python爬虫实战】DrissionPage 与 ChromiumPage:高效网页自动化与数据抓取的双利器
  • 【AI】【提高认知】卷积神经网络:从LeNet到AI淘金热的深度学习之旅
  • 一、数据操作
  • 5G NR物理层|5G PHY层概述
  • 【SpringCloud】Nacos微服务注册中心
  • 【LeetCode】【算法】416. 分割等和子集
  • STM32F1 LL 库和HAL 库在GPIO 上的区别
  • 从0开始学习机器学习--Day13--神经网络如何处理复杂非线性函数
  • 【JavaEE】常见锁策略、CAS
  • python --03 (数据类型)
  • 【持续更新】【NLP项目】【自然语言处理】智能聊天机器人——“有问必答”【Chatbot】第2章、《模式一:问候模式》
  • Qt——窗口
  • 阿里云 DataWorks 正式支持 SelectDB Apache Doris 数据源,实现 MySQL 整库实时同步
  • Golang | Leetcode Golang题解之第542题01矩阵
  • Spring Boot 与 Vue 共筑航空机票预定卓越平台
  • Docker LLama-Factory vLLM 快速部署Meta-Llama-3.1-70B-Instruct
  • 银行卡二要素核验 API 对接说明
  • uniapp 实现瀑布流