vue-cli模擬後臺數據交互

来源:https://www.cnblogs.com/kingsnowcan/archive/2018/06/05/snow_20180605.html
-Advertisement-
Play Games

作為一個前端入坑的妹子,在學習vue的道路上掙扎徘徊,由一開始的對vue一直蒙圈只知道雙向數據綁定和一些'V-x'的指令,慢慢通過一個視頻的學習漸漸入坑,對於我這個js基礎不怎麼好而且編程思維又不是很嚴謹的人來說還是踩了很多坑,特別是vue配置方面的東西,例如vue-router,vueX,雖然是跟 ...


作為一個前端入坑的妹子,在學習vue的道路上掙扎徘徊,由一開始的對vue一直蒙圈只知道雙向數據綁定和一些'V-x'的指令,慢慢通過一個視頻的學習漸漸入坑,對於我這個js基礎不怎麼好而且編程思維又不是很嚴謹的人來說還是踩了很多坑,特別是vue配置方面的東西,例如vue-router,vueX,雖然是跟著視頻做的,不過每次都有很多地方配置不正確,會報錯,特別是最近在跟著視頻做一個前端的web頁面其中涉及到前後臺數據交互方面的說到模擬後臺數據的問題,完全懵逼,剛開始都不知哪個文件怎麼配置,終於通過網上各種搜索,弄清楚了一些問題附上鏈接     https://blog.csdn.net/weixin_39728230/article/details/80293892

一、模擬後臺數據介面,一般我們用的ajax但是vue裡面要用vue-resource這個組件去請求數據,當然不可避免首先要先下載這個組件,方法如下

1、npm install vue-resource --save

2、main.js文件引入vue-resource:

          import VueResource from 'vue-resource'

         Vue.use(VueResource)

準備工作就緒以後就可以開始模擬後臺數據介面配置了,有兩種方法,一種是利用一個插件json-server來模擬還有就是利用express方法,支持get和post請求,據說更加通用

create: function(){
      //this.$http.get('getList')//ajax請求
      this.$http.post('getLisst',{userId:123})
      .then(function(data){
        console.log(data)//成功回調
      },function(err){
        console.log(err)//失敗回調
      })
  },

上面這個是在組件中vue調後臺數據的get和post請求的寫法,post請求可以帶參數傳遞

接下來重要的來了方法一:安裝json-server來配置數據

第一步:安裝json-server這裡啰嗦一句,vue裡面所有需要用到的組件都要用 npm install xxx(組件名)來安裝

             npm install json-server --save

第二步:安裝成功之後,接下來就是配置,這裡說一下,之前看視頻上說配置是在bulid/dev-server.js文件中配置,結果找了半天沒找到,似乎是vue2.0刪除了那個文件,把它裡面的配置放置在了build/webpack.dev.conf.js這個文件裡面,如下圖代碼可以直接放在該文件最下方

              

//這裡是json-server配置信息  
//json-server.js  
const jsonServer = require('json-server')  
const apiServer = jsonServer.create()  
const apiRouter = jsonServer.router('db.json') //數據關聯server,db.json與index.html同級  
const middlewares = jsonServer.defaults()  
  
apiServer.use(middlewares)  
apiServer.use('/api',apiRouter)  
apiServer.listen(3000, () => {                 //監聽埠  
  console.log('JSON Server is running')  
})  

第三步:配置完webpack.dev.conf.js文件之後,差不多進行了一半,配置裡面看到有個db.json文件這個就是我們自己配置的數據源

           

          這裡面就是我們自己寫的數據源代碼

        

{
    "getNewsList": [
      {
        "id": 1,
        "title": "新聞條目1新聞條目1新聞條目1新聞條目1",
        "url": "http://starcraft.com"
      },
      {
        "id": 2,
        "title": "新聞條目2新聞條目2新聞條目2新聞條目2",
        "url": "http://warcraft.com"
      },
      {
        "id": 3,
        "title": "新聞條3新聞條3新聞條3",
        "url": "http://overwatch.com"
      },
      {
        "id": 4,
        "title": "新聞條4廣告發佈",
        "url": "http://hearstone.com"
      }
    ]
}

第四步:然後我們看到我們監聽的是3000的埠,而我們文件用的是8080的埠,這裡就涉及跨域的問題,雖然不是很懂,不過還是知道一些不同埠號什麼的不能請求數據(這裡不是很懂有機會再回顧一下看看),那接下來就是解決跨域的問題了,不多說,找到config文件夾下麵的index.js文件打開加入下麵一段代碼

 proxyTable:{
      '/api':'http://localhost:3000/'
    },

至於位置的話請看下麵:

第五步:到這裡基本配置完成需要你重新npm run dev一下然後打開網頁 http://localhost:8080/api/getNewsList 就可以看到你寫的數據

       

這裡代表你的json server啟動成功

     

這裡就是你配置的介面數據

方法二:express方法,支持get和post請求,據說更加通用,不過我還沒試用,一樣的方法

第一步:先找到webpack.dev.conf.js然後在頭部引入express:

         var express = require('express')  //這裡沒有寫,會提示apiServer = express()這裡express()未定義!!

        然後在文件底部加上如下代碼:   

//express 配置server  
var apiServer = express()  
var bodyParser = require('body-parser')  
apiServer.use(bodyParser.urlencoded({ extended: true }))  
apiServer.use(bodyParser.json())  
var apiRouter = express.Router()  
var fs = require('fs')  
apiRouter.route('/:apiName') //介面路徑  
  .all(function (req, res) {  
    fs.readFile('./db.json', 'utf8', function (err, data) {  //讀取介面文件  
      if (err) throw err  
      var data = JSON.parse(data)  
      if (data[req.params.apiName]) {  
        res.json(data[req.params.apiName])  
      }  
      else {  
        res.send('no such api name')  
      }  
  
    })  
  })  
  
apiServer.use('/api', apiRouter);  
apiServer.listen(3000, function (err) {  
  if (err) {  
    console.log(err)  
    return  
  }  
  console.log('Listening at http://localhost:' + 3000 + '\n')  
})  

第二步:然後一樣的要配置index.js 裡面跨域的問題還有json數據的創建

同上面index.js一樣的位置一樣的代碼

第三步:同樣的訪問那個鏈接就可以看到數據

最後,希望能對大家有所幫助,第一次寫,有什麼需要交流的請多指出,謝謝


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 搭建第一個htttp伺服器 1.核心代碼 訪問路徑查看結果: 2.知識要點 require: 用於載入核心模塊,fs,http等 server: 提供Web服務(發送請求,處理請求,處理數據,發送響應) request: 請求對象,發送請求的客戶端的對象,可以獲取客戶端的請求信息 response: ...
  • 一、JQuery介紹 二、JQuery的優勢 三、jQuery庫包含功能 HTML元素選取 HTML元素操作 CSS操作 HTML事件函數 JavaScript特效和動畫 HTMLDOM遍歷和修改 AJAX Utilites 四、jQuery版本支持 1.x:相容IE768,使用最為廣泛的,官方只做 ...
  • 比如 、`left transform translate`方法,他們的百分比都是相較誰而言的? 、`left`是基於父元素的: translate的參數:left(x 坐標) 和 top(y 坐標) 位置參數 , 如果是百分比,會以本身的長寬做參考 的時候: 把 設置成 的時候, 的左、上距離就是 ...
  • HTML 文檔中的所有內容都是節點: 整個文檔是一個文檔節點 document 每個 HTML 元素是元素節點 element HTML 元素內的文本是文本節點 每個 HTML 屬性是屬性節點 註釋是註釋節點 圍繞DOM節點的操作可以概括為四種:增、刪、改、查 一、增: 增加新元素 如需向 HTML ...
  • JavaScript 是允許你在網頁中實現複雜事情的一門編程語言 —— 每次當你瀏覽網頁時不只是顯示靜態信息—— 顯示即時更新的內容, 或者互動式的地圖,或 2D/3D 圖形動畫,又或者自動播放視頻等,你可以確信,JavaScript 參與其中。 ...
  • 【註:以下內容參考https://blog.csdn.net/stilling2006/article/details/54376743】 一、認識Sublime text 1、一款跨平臺代碼編輯器,在Linux、OSX和Windows下均可使用; 2、可擴展,包含大量實用插件,可以通過安裝自己領域 ...
  • CSS學習摘要 定位實例 === 註:全文摘自 "MDN CSS定位實例" 列表消息盒子 我們研究的第一個例子是一個經典的選項卡消息框,你想用一塊小區域包括大量信息時,一個非常常用的特征。這包括含有大信息量的應用,比如策略戰爭游戲,比如從移動版的網頁,屏幕狹小、空間有限;比如你可能想要放置許多信息的 ...
  • +++++{{msg}}----- ========== 百度一下,不跳轉 百度一下,跳轉 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...