VUE+node(express)實現前後端分離
阿新 • • 發佈:2020-11-19
vue作為前端的框架,node(express)作為後端的框架。無資料庫,使用埠儲存資料。 VUE:
使用vue-cli構建vue專案(vueapp)。
npm install -g vue-cli(安裝,安裝過的就不用了) vue init webpack vueapp
axios:(與ajax相似)
import axios from 'axios' var url="http://localhost:3000" //express伺服器的地址 axios.get(url+'/product') //放資料的介面 .then(function (response) { //收到的資料 console.log(response); console.log(response.data); //展示資料(看看是否拿到,和資料長啥樣) var nodeData=response.data; }) .catch(function (error) { console.log(error);![在這裡插入圖片描述](https://img-blog.csdnimg.cn/20191013132943460.jpg) });
axios沒安裝的記得裝一下。(安裝不細說)
node(express): 啟動>>>npm start
使用express構建伺服器:
新建個myapp放express npm install express
在(routes資料夾中)建一個product,js介面
var express = require('express'); //使用express var router = express.Router(); //放資料 /* GET home page. */ router.get('/', function (req, res, next) { var data = { code: 0, data: { name: 'aaa', pwd: '123' }, isSuccess: true, msg: "請求成功" } res.json(data); }); module.exports = router;
app.js(建立介面存放資料)
var productRouter = require('./routes/product'); app.use('/product', productRouter);
最後伺服器資料有了!!!!VUE前端接收資料的連結也有了!!!但還是沒辦法連結!!!!這就是跨域的問題!!!
跨域:
1.埠不同 http://localhost:3000和http://localhost:8080
2.網址不同 www.baidu.com和www.aiqiyi.com
3.ip和網址不同 http://localhost:3000和http://127.0.0.1
反正除非同個網址裡面,只有目錄不同,才不用跨域。
開始解決!!
express>>>app.js
//跨域問題解決方面 const cors = require('cors'); app.use(cors({ origin:['http://localhost:8080'], methods:['GET','POST'], })); //跨域問題解決方面 app.all('*',function (req, res, next) { res.header('Access-Control-Allow-Origin', 'http://localhost:8080'); res.header('Access-Control-Allow-Headers', 'Content-Type'); res.header('Access-Control-Allow-Methods', 'PUT, POST, GET, DELETE, OPTIONS'); next(); });
cors需要安裝,是一個依賴。
結果:
伺服器(express):3000介面資料
搞定了,以上就是本次介紹的全部知識點,感謝大家的學習和對碼農教程的支援。