亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

vue項目中mock.js的使用及基本用法

2019-11-19 11:30:02
字體:
來源:轉載
供稿:網友

官方網址:http://mockjs.com/

mockjs是用來模擬產生一些虛擬的數據,可以讓前端在后端接口還沒有開發出來時獨立開發。我們可以使用真實的url,mockjs可以攔截ajax請求,返回設定好的數據。

使用方式

這里主要討論在vue項目中,使用axios發送ajax請求,mock.js模擬數據的流程。

vue-cli搭建項目后,安裝axios和mock.js

npm install -S axiosnpm install -D mockjs

在項目中新建mock.js文件夾,來設置要產生的模擬數據的格式。

3. 設想這樣一個場景,頁面在打開時要從數據庫獲取一個新聞列表,現在我們要模擬這個列表,新聞對象包括新聞標題、新聞內容和創建時間三項。

// mock.js// 引入mockjsconst Mock = require('mockjs')// 獲取 mock.Random 對象const Random = Mock.Random// mock新聞數據,包括新聞標題title、內容content、創建時間createdTimeconst produceNewsData = function () { let newsList = [] for (let i = 0; i < 20; i++) { let newNewsObject = { title: Random.ctitle(), // Random.ctitle( min, max ) 隨機產生一個中文標題,長度默認在3-7之間 content: Random.cparagraph(), // Random.cparagraph(min, max) 隨機生成一個中文段落,段落里的句子個數默認3-7個 createdTime: Random.date() // Random.date()指示生成的日期字符串的格式,默認為yyyy-MM-dd; } newsList.push(newNewsObject) } return newList}// 請求該url,就可以返回newsListMock.mock('/mock/news', produceNewsData) // 后面講這個api的使用細節

在main.js引入該mock.js文件,表明我們使用這里面產生的數據。

// main.jsimport Vue from 'vue'import App from './App'import router from './router'require(./mock.js)

在APP.vue里我們來發送get請求獲取數據

// App.vue<template> <div id="#app"></div></template><script>import axios from 'axios' // 引入axiosexport default { // 掛載的時候獲取新聞列表 mounted() { axios.get('/mock/news').then(res => { // url即在mock.js中定義的 console.log(res.data) // 打印一下響應數據 }) }}</script>

運行項目打開控制臺可以看到,我們拿到了模擬的數據。

Mock.mock()

Mock.mock( rurl, rtype, template|function( options ) )rurl可選。表示需要攔截的 URL,可以是 URL 字符串或 URL 正則。例如 '/domian/list.json'。rtype可選。表示需要攔截的 Ajax 請求類型。例如 GET、POST、PUT、DELETE 等。template可選。表示數據模板,可以是對象或字符串。數據模板中的每個屬性由 3 部分構成:屬性名、生成規則、屬性值:// 屬性名 name// 生成規則 rule// 屬性值 value'name|rule': value例如:'name|1-10':1 會產生一個1-10之間的整數,詳細規則參見官方文檔function(options)可選。表示用于生成響應數據的函數。options指向本次請求的 Ajax 選項集,含有 url、type 和 body 三個屬性

增加數據

之前討論的都是產生好數據供我們獲取,如果想測試增加數據的功能,mock.js也可以實現,對于 Mock.mock(url,function(ops)) ,ops參數就可以拿到傳送的數據。

// App.vue<template> <div id="app"> <div> <input type="text" v-model="title"> <button type="button" @click="submit">提交</button> <button type="button" @click="getProjects">獲取</button> </div> </div></template><script>import axios from 'axios'export default { data () { return { title: '' } }, methods: { submit () { axios.post('/mock/addProject', { // 添加數據的接口,數據為一個對象,有個title屬性 title: this.title }) }, getProjects () { axios.get('/mock/projects').then(res => { // 獲取數據 console.log(res.data)  }) } }}</script>

我們在mock.js中模擬一個添加數據的接口,拿到數據后存到數組中。

// mock.js// 添加信息let projectList = []Mock.mock('/mock/addProject', ops => { // 攔截ajax請求,調用函數 console.log(ops) // 先看一下這個ops是什么 projectList.push(ops)})// 獲取信息Mock.mock('/mock/projects', projectList)

在輸入框中輸入標題后,點擊提交,數據發送到/mock/addProject, mock.js攔截到請求后,調用function(ops)方法,打印看到ops是個對象,有3個屬性,url,type和body,而我們輸入的數據就在body屬性值里,同時因為axios默認發送的是json格式的數據,所以body里面的數據是json串,更改function(ops)函數,將數據以js對象的形式存入數組中。當然實際開發中可以看后端的數據返回格式,選擇在前端進行json轉js的操作,這里只是演示一下。

// mock.js// 添加信息let projectList = []Mock.mock('/mock/addProject', ops => { // 攔截ajax請求,調用函數 // console.log(ops) // 先看一下這個ops是什么 ops = JSON.parse(ops.body) projectList.push(ops)})// 獲取信息Mock.mock('/mock/projects', projectList)

更改后輸入標題,點擊提交,再點擊獲取,可以看到返回了我們提交的數據,并且是js對象的形式,拿到數據后就可以做進一步的操作了。

修改功能的代碼也是類似的。

刪除數據

刪除數據一般是把數據的id以get形式傳遞給后端,url形式為: /xxx/xxx?id=value, 實際開發中后端可以很好的處理id值不同的url,我們只需要關心怎么獲取到id,但是使用mock.js時,攔截的url我不知道怎么寫成動態的. Mock.mock('/mock/delete') ,此時使用axios.get()時就會報錯:

所以還是改成了用post傳遞的方式。

不知道是不是有什么別的方法,可以使得刪除時使用get請求。

總結

以上所述是小編給大家介紹的vue項目中mock.js的使用及基本用法,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對武林網網站的支持!
如果你覺得本文對你有幫助,歡迎轉載,煩請注明出處,謝謝!

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲最大成人免费视频| 国产成人精品免费久久久久| 国产精品稀缺呦系列在线| 欧美日韩一区二区在线播放| 久久精品2019中文字幕| 97在线视频国产| 中文字幕亚洲综合| 久久在线观看视频| 国产剧情日韩欧美| 亚洲3p在线观看| 欧美另类极品videosbest最新版本| 成人免费看吃奶视频网站| 川上优av一区二区线观看| 亚洲一区二区自拍| 久久天天躁狠狠躁夜夜躁2014| 2020欧美日韩在线视频| 91国内精品久久| 久久久国产一区二区三区| 国产精品免费久久久久久| 亚洲肉体裸体xxxx137| 在线日韩中文字幕| 国产精品久久久久久久久久东京| 亚洲国产精品一区二区三区| 欧美极品少妇xxxxⅹ喷水| 亚洲国产成人91精品| 欧美日韩激情视频8区| 91在线色戒在线| 亚洲午夜久久久影院| 九色精品美女在线| 国产在线精品成人一区二区三区| 国产精品日韩一区| 91精品视频免费看| 亚洲大胆美女视频| 麻豆国产va免费精品高清在线| 亚洲欧美国产一本综合首页| 欧美激情乱人伦一区| 精品久久久久久国产91| 国产一区二区日韩| 亚洲精品国产精品乱码不99按摩| 亚洲变态欧美另类捆绑| 91免费看视频.| 久久99国产精品自在自在app| 中文字幕亚洲综合久久筱田步美| 日本免费一区二区三区视频观看| 91av国产在线| 欧美精品久久久久久久久久| 欧美在线xxx| 国产亚洲精品久久久久久777| 亚洲国产成人久久综合一区| 亚洲网站视频福利| 精品无码久久久久久国产| 久久亚洲精品毛片| 亚洲成色777777女色窝| 国产欧美日韩91| 日韩精品丝袜在线| 国产精品一二三在线| 97在线视频免费| 午夜精品久久久久久99热| 日韩激情视频在线播放| 亚洲黄色av网站| 欧美日韩综合视频| 欧美整片在线观看| 欧洲午夜精品久久久| 日韩三级影视基地| 成人妇女免费播放久久久| 国产欧美在线播放| 成人激情免费在线| 国产美女扒开尿口久久久| 69国产精品成人在线播放| 亚洲精品电影网| 成人444kkkk在线观看| 欧美精品电影在线| 亚洲欧美资源在线| 精品爽片免费看久久| 亚洲第一福利在线观看| 日韩精品视频在线免费观看| 视频直播国产精品| 黑人狂躁日本妞一区二区三区| 91欧美视频网站| 菠萝蜜影院一区二区免费| 国产在线观看精品一区二区三区| 欧美xxxx综合视频| 国产拍精品一二三| 日韩av在线网站| 日韩精品在线免费| 在线观看欧美www| 成人午夜激情免费视频| 亚洲va欧美va国产综合久久| 亚洲一区中文字幕在线观看| 亚洲第一av网| 国产精品久久久久久av福利| 亚洲午夜av久久乱码| 成人精品网站在线观看| 国产成人在线一区二区| 精品视频在线观看日韩| 欧美亚洲国产日韩2020| 亚洲在线免费看| 97久久久免费福利网址| 久久久久久久久国产精品| 国产在线精品播放| 欧美黄色片在线观看| 国产精品久久久久久久9999| 亚洲国产精品久久久久秋霞蜜臀| 欧美最近摘花xxxx摘花| 久久久亚洲影院你懂的| 亚洲精品美女久久久| 国产欧美日韩免费看aⅴ视频| 国产欧美日韩丝袜精品一区| 亚洲a在线播放| 亚洲色图激情小说| 久久亚洲成人精品| 视频一区视频二区国产精品| 国产成人极品视频| 亚洲成人亚洲激情| 亚洲人av在线影院| 精品欧美国产一区二区三区| 国产日韩欧美影视| 欧美成人激情视频免费观看| 奇米四色中文综合久久| 亚洲精品小视频| 中文字幕视频在线免费欧美日韩综合在线看| 日韩精品亚洲精品| 日韩欧美在线第一页| 亚洲免费福利视频| 国产999精品久久久| 久久久人成影片一区二区三区观看| 久久久久久久久久婷婷| 91伊人影院在线播放| 日韩电影免费观看中文字幕| 欧美大码xxxx| 中日韩美女免费视频网址在线观看| 欧美高清激情视频| 国产成人精品免费视频| 国产一区二区三区18| 国产精品av在线播放| 日本成熟性欧美| 国产亚洲美女精品久久久| 国产综合在线观看视频| 国产在线观看精品| 国产91在线播放精品91| 国产成人综合精品| 亚洲区中文字幕| 成人妇女免费播放久久久| 欧洲美女7788成人免费视频| 欧美日韩在线另类| www.亚洲男人天堂| 亚洲人成绝费网站色www| 韩日精品中文字幕| 久久久久久久999| 国产精自产拍久久久久久蜜| 国产美女久久精品| 国产精品极品在线| 久久成人人人人精品欧| 欧美性猛交xxxx免费看| 91牛牛免费视频| 高跟丝袜一区二区三区| 日韩精品小视频| 97香蕉久久超级碰碰高清版| 日韩免费观看在线观看| 久久久久久91| 国产精品久久久久久久久免费| 日韩av在线看| 欧美夫妻性生活视频| 中文字幕亚洲自拍|