Spring Boot + Vue CLI 前後端分離入門(配置&步驟)
data:image/s3,"s3://crabby-images/8ff0a/8ff0a41c35918042b03240215d0ef58aeacca83a" alt=""
(1) 安裝配置 Vue CLI
首先我們要使用 npm 安裝 Vue CLI,必須要先安裝Node.js
安裝 Node.js,官網下載即可 https://nodejs.org/en/
左邊是推薦版,右邊是最新版,兩個其實都可以
我是下載左邊的版本,下載好後,跟著步驟一路安裝到底即可
data:image/s3,"s3://crabby-images/33f73/33f731332f3f8a7bdbaa3c252fa12f2f7f7ef1d9" alt=""
data:image/s3,"s3://crabby-images/b9c84/b9c8470bca76907bb77f5b8daeecc65129d62a62" alt=""
安裝完之後, 在 cmd 輸入 node -v , 確認是否安裝成功
這同時, npm 也安裝完成, 可以輸入 npm -v 查看版本
接著輸入 npm -g install npm 將 npm 更新到最新版
更新完後輸入 npm install -g vue-cli 安裝 Vue CLI
data:image/s3,"s3://crabby-images/da767/da767e742aeb8c8e53bd5785abfc9a9e56dac7a3" alt=""
接著可以開始建立前端項目
到一個目錄, 新增一個資料夾 C:\testWorkspace
輸入指令 vue init webpack wj-vue
這邊是以 webpack 當作模板
wj-vue 是Project Name , 可以換成自己喜歡的
會問你是不是要安裝 vue-router , 要選 Y
data:image/s3,"s3://crabby-images/6be62/6be626e81bfd9ee1e7342b551510fb5c218f80b9" alt=""
data:image/s3,"s3://crabby-images/e3f02/e3f021a30d1ec58fa68579a6e27445dbbc9b84c6" alt=""
安裝完之後, 到目錄內執行
需要在该文件夹 C:\testWorkspace\wj-vue
執行 npm install
然後執行 npm run dev
data:image/s3,"s3://crabby-images/de5bb/de5bbe6de710baf48c4e98539457b7708175b23c" alt=""
接著就到 http://localhost:8080 如果有看到下面網頁, 代表 Vue CLI 建置成功!!
data:image/s3,"s3://crabby-images/9c2a9/9c2a9ff6feb076b2759ea90d3054903e46974048" alt=""
(2) 安裝配置 Spring Boot
先到Eclipse Marketplace , 安裝 Tool
data:image/s3,"s3://crabby-images/8b1cb/8b1cbc13afa0e36b72968c067110cd2f36ce2b96" alt=""
安裝完之後, 工作區右鍵, 選擇 Spring Starter Project
data:image/s3,"s3://crabby-images/2d5cb/2d5cb153ffe7975f2f667a9204822da1d366123f" alt=""
可以改名稱跟一些設定, Packaging 可以選 jar war 之類
data:image/s3,"s3://crabby-images/b107e/b107e85f20b3a01940719f6226ead5b53ea9154b" alt=""
這裡我有參考網路的, 所以我也是選 Spring Reactive Web
data:image/s3,"s3://crabby-images/f6cd1/f6cd1fe203f0830a09b41027f32095f43265c062" alt=""
建好後, 專案目錄大概會長這樣
data:image/s3,"s3://crabby-images/45028/450289d2930bd3b625962130737ebfa7d003626c" alt=""
接著我們到 Application.java配置設定
#context path server.servlet.context-path=/MySpringBoot #port server.port=8005
data:image/s3,"s3://crabby-images/b3d7a/b3d7acaeb0aa94f98cea6a119d29924a9e2320fa" alt=""
接著新增一隻 controller
@Controller public class testController { private dataBean studentRecords; @RequestMapping(method = RequestMethod.GET, value="/test") @ResponseBody public String test() { return "TEST"; } @RequestMapping(method = RequestMethod.GET, value="/student/allstudent") @ResponseBody public dataBean getAllStudents() { studentRecords = new dataBean(); studentRecords.setName("Ray"); studentRecords.setAge(30); return studentRecords; } }
接著專案右鍵, run Spring Boot App
data:image/s3,"s3://crabby-images/44283/4428315fb475cf850ba67bc4b47a47afe250c966" alt=""
看到下面console 代表成功
data:image/s3,"s3://crabby-images/72bbc/72bbc24fd5fcb5eef03ffd78be2a30fa6b04f63a" alt=""
先試試看 是不是可以呼叫到 http://localhost:8005/MyFirstSpringBoot/test
如果看到頁面出現 TEST , 代表成功
data:image/s3,"s3://crabby-images/d94eb/d94ebf7beffaf45d46378331074efb7179efa394" alt=""
最後, 我們回到 Vue CLI, 試著呼叫 /student/allstudent
先找到 config 下面的 index.js
data:image/s3,"s3://crabby-images/5d1d7/5d1d75fbaae1a7256ce08e305610f6a19764fa2f" alt=""
修改 proxyTable 如下,這段的意思是,讓前面固定的 URL 名稱,改為用data
這樣前面程式呼叫的時候, 會乾淨許多
proxyTable: { '/data': { target: 'http://localhost:8005/MySpringBoot/', changeOrigin: true, pathRewrite: { '^/data': '' } } },
接著到 App.vue
data:image/s3,"s3://crabby-images/eb39c/eb39c02bf3619f1206c705c9fc869d858cb477dd" alt=""
把攏長的URL http://localhost:8005/MySpringBoot/student/allstudent 簡化為 /data/student/allstudent
修改 created
<script> import Vue from 'vue' import axios from 'axios' import VueAxios from 'vue-axios' Vue.use(VueAxios, axios) export default { name: 'App', created () { Vue.axios .get('/data/student/allstudent') .then((response) => { console.log(response.data) }) .catch((error) => { console.log(error) }) } }
修改好之後, 重啟一次 Vue CLI
在重新整理一次
就會看到console 呼叫的資料回來了
data:image/s3,"s3://crabby-images/7f5fd/7f5fd1f2f2a8853fa4f88ee602b3afbf6d695e94" alt=""
喜欢我的作品吗?别忘了给予支持与赞赏,让我知道在创作的路上有你陪伴,一起延续这份热忱!