1500字范文,内容丰富有趣,写作好帮手!
1500字范文 > Node.js+Express+Vue+MySQL+axios的项目搭建

Node.js+Express+Vue+MySQL+axios的项目搭建

时间:2023-06-06 20:58:06

相关推荐

Node.js+Express+Vue+MySQL+axios的项目搭建

1 基本搭建

创建vue项目之前需要先安装Node.js和MySQL数据库

1.1 vue脚手架安装

npm i vue -gnpm i @vue/cli -g//初始化vue项目vue create 项目名

1.2 在创建好的项目中创建server文件夹

在文件夹内创建这几个文件:

新建api文件夹、db.js、index.js、sqlMap.js。(api文件存放相关api接口路径及方法,db.js配置相关数据库,index.js配置后端端口及api路由)

index.js

const userApi = require('./api/userApi');const fs = require('fs');const path = require('path');const bodyParser = require('body-parser');const express = require('express');const app = express();app.use(bodyParser.urlencoded({extended: true}));app.use(bodyParser.json());// 后端api路由app.use('/api/user', userApi);// 监听端口app.listen(3000);console.log('success listen at port:3000......');

db.js

//数据库配置信息 并进行导出module.exports ={mysql:{host: 'localhost',user: 'root',password: '123456',database: 'h5',port: '3306'}}

sqlMap.js

var sqlMap = {// 用户user: {add: 'insert into user(name,age) values(?,?)',update:'....'},//商品goods:{add:'insert into goods(name,desc,price,num) value(?,?,?,?)'},//订单orders:{....}}module.exports = sqlMap;

userApi.js

//引入express,调用路由模块var express = require('express');var router = express.Router();//引入mysql,mysql配置文件var models = require('../db');var mysql = require('mysql');var $sql = require('../sqlMap');// 连接数据库var conn = mysql.createConnection(models.mysql);conn.connect();var jsonWrite = function(res, ret) {if(typeof ret === 'undefined') {res.json({code: '1',msg: '操作失败'});} else {res.json(ret);}};// 增加用户接口 完整进入该post的路径问index.js里面配置的路由加上该post的路径// '/api/user/addUser'router.post('/addUser', (req, res) => {let sql = $sql.user.add;let params = req.body;console.log(params);conn.query(sql, [params.name, params.pass], function(err, result) {if (err) {console.log("添加失败"+err);}if (result) {jsonWrite(res, result);}})});module.exports = router;

1.3 编写前端界面

在src的views目录下建一个前端界面

<template><div class="home"><form action="http://localhost:3000/api/user/addUser" method="post">user:<input type="text" name="name" /><br>pass:<input type="password" name="pass" /><br><input type="submit"/></form><button type="button" @click="addUser">post添加用户</button></div></template><script>export default {name: 'Home',methods:{addUser(){// console.log(111)//发起ajax请求//使用axios请求}}}</script>

1.4 启动服务测试

此时我们还没有安装mysql模块

npm i mysql --save

同时启动前端和后端的服务

输入数据测试:

数据插入成功!

这里需要注意一点:

前端界面表单中的name要和数据库中的字段一致,不然数据不能插入数据库而显示为NULL

2 axios的使用

axios安装和使用

安装axios

npm i --save axios

在vue项目中的main.js中引入axios

// 引入axiosimport axios from 'axios'//全局注册axiosVue.prototype.$axios=axios

<template><div class="home"><form action="http://localhost:3000/api/user/addUser" method="post">user:<input type="text" name="name" /><br>pass:<input type="password" name="pass" /><br><input type="submit"/></form><button type="button" @click="selectUser">post添加用户</button></div></template><script>export default {name: 'Home',methods:{selectUser(){// console.log(111)//发起ajax请求//使用axios请求// console.log(this.$axios)this.$axios({url:'http://localhost:3000/api/user/',//请求的url地址method:'post',data:{name:'胡桃',},}).then(function(data){console.log(data)}).catch(function(err){console.log(err)})}}}</script>

测试报错,因为Node后端和vue端端口不一致,需要跨域

配置proxy进行跨域请求

vue根目录找到vue.config.js,如果没有就手动创建一个

module.exports={devServer:{proxy:{//配置跨域'/api':{target:'http://localhost:3000/',//这里填写真实的后台接口changeOrigin:true,//允许跨域pathRewrite:{/* 重写路径,当我们在浏览器中看到请求的地址为:http://localhost:8080/api/core/getData/userInfo 时实际上访问的地址是:http://121.121.67.254:8185/core/getData/userInfo,因为重写了 /api*/'^/api':'/'}}}}}

userApi.js中新增一个post

router.post('/selectUser', (req, res) => {console.log(req.body);});

<template><div class="home"><form action="http://localhost:3000/api/user/addUser" method="post">user:<input type="text" name="name" /><br>pass:<input type="password" name="pass" /><br><input type="submit"/></form><button type="button" @click="selectUser">post添加用户</button></div></template><script>export default {name: 'Home',methods:{selectUser(){// console.log(111)//发起ajax请求//使用axios请求// console.log(this.$axios)this.$axios({url:'/api/api/user/selectUser',//请求的url地址method:'post',data:{name:'胡桃',},}).then(function(data){console.log(data)}).catch(function(err){console.log(err)})}}}</script>

重启前端和后端服务,点击按钮

查看后台控制台

跨域请求数据成功!

proxy写多个代理

module.exports={devServer:{proxy:{//配置跨域'/api/select':{target:'http://localhost:3000/',//这里填写真实的后台接口changeOrigin:true,//允许跨域pathRewrite:{'^/api/select':''}},'/api':{target:'http://localhost:3000/',//这里填写真实的后台接口changeOrigin:true,//允许跨域pathRewrite:{// api代表网址是: http://localhost:3000/api/user'^/api':''}},}}}

前端url路径写成哪个都可以跨域请求到数据

代码更改后需要充钱前端服务

简写代码:

同理,我们把第二个代理修改

但是这里测试请求失败,

我们做如下修改:

最终就可以测试成功了!

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。