1. 程式人生 > 實用技巧 >VUE+node(express)實現前後端分離

VUE+node(express)實現前後端分離

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介面資料


搞定了,以上就是本次介紹的全部知識點,感謝大家的學習和對碼農教程的支援。