官方網(wǎng)址:http://mockjs.com/
成都創(chuàng)新互聯(lián)專業(yè)為企業(yè)提供雁江網(wǎng)站建設(shè)、雁江做網(wǎng)站、雁江網(wǎng)站設(shè)計、雁江網(wǎng)站制作等企業(yè)網(wǎng)站建設(shè)、網(wǎng)頁設(shè)計與制作、雁江企業(yè)網(wǎng)站模板建站服務(wù),十多年雁江做網(wǎng)站經(jīng)驗,不只是建網(wǎng)站,更提供有價值的思路和整體網(wǎng)絡(luò)服務(wù)。
mockjs是用來模擬產(chǎn)生一些虛擬的數(shù)據(jù),可以讓前端在后端接口還沒有開發(fā)出來時獨立開發(fā)。我們可以使用真實的url,mockjs可以攔截ajax請求,返回設(shè)定好的數(shù)據(jù)。
使用方式
這里主要討論在vue項目中,使用axios發(fā)送ajax請求,mock.js模擬數(shù)據(jù)的流程。
vue-cli搭建項目后,安裝axios和mock.js
npm install -S axios npm install -D mockjs
在項目中新建mock.js文件夾,來設(shè)置要產(chǎn)生的模擬數(shù)據(jù)的格式。
3. 設(shè)想這樣一個場景,頁面在打開時要從數(shù)據(jù)庫獲取一個新聞列表,現(xiàn)在我們要模擬這個列表,新聞對象包括新聞標(biāo)題、新聞內(nèi)容和創(chuàng)建時間三項。
// mock.js // 引入mockjs const Mock = require('mockjs') // 獲取 mock.Random 對象 const Random = Mock.Random // mock新聞數(shù)據(jù),包括新聞標(biāo)題title、內(nèi)容content、創(chuàng)建時間createdTime const produceNewsData = function () { let newsList = [] for (let i = 0; i < 20; i++) { let newNewsObject = { title: Random.ctitle(), // Random.ctitle( min, max ) 隨機(jī)產(chǎn)生一個中文標(biāo)題,長度默認(rèn)在3-7之間 content: Random.cparagraph(), // Random.cparagraph(min, max) 隨機(jī)生成一個中文段落,段落里的句子個數(shù)默認(rèn)3-7個 createdTime: Random.date() // Random.date()指示生成的日期字符串的格式,默認(rèn)為yyyy-MM-dd; } newsList.push(newNewsObject) } return newList } // 請求該url,就可以返回newsList Mock.mock('/mock/news', produceNewsData) // 后面講這個api的使用細(xì)節(jié)
在main.js引入該mock.js文件,表明我們使用這里面產(chǎn)生的數(shù)據(jù)。
// main.js import Vue from 'vue' import App from './App' import router from './router' require(./mock.js)
在APP.vue里我們來發(fā)送get請求獲取數(shù)據(jù)
// App.vue <template> <div id="#app"></div> </template> <script> import axios from 'axios' // 引入axios export default { // 掛載的時候獲取新聞列表 mounted() { axios.get('/mock/news').then(res => { // url即在mock.js中定義的 console.log(res.data) // 打印一下響應(yīng)數(shù)據(jù) }) } } </script>
運(yùn)行項目打開控制臺可以看到,我們拿到了模擬的數(shù)據(jù)。
Mock.mock()
Mock.mock( rurl, rtype, template|function( options ) ) rurl 可選。 表示需要攔截的 URL,可以是 URL 字符串或 URL 正則。例如 '/domian/list.json'。 rtype 可選。 表示需要攔截的 Ajax 請求類型。例如 GET、POST、PUT、DELETE 等。 template 可選。 表示數(shù)據(jù)模板,可以是對象或字符串。 數(shù)據(jù)模板中的每個屬性由 3 部分構(gòu)成:屬性名、生成規(guī)則、屬性值: // 屬性名 name // 生成規(guī)則 rule // 屬性值 value 'name|rule': value 例如:'name|1-10':1 會產(chǎn)生一個1-10之間的整數(shù),詳細(xì)規(guī)則參見官方文檔 function(options) 可選。 表示用于生成響應(yīng)數(shù)據(jù)的函數(shù)。 options 指向本次請求的 Ajax 選項集,含有 url、type 和 body 三個屬性
增加數(shù)據(jù)
之前討論的都是產(chǎn)生好數(shù)據(jù)供我們獲取,如果想測試增加數(shù)據(jù)的功能,mock.js也可以實現(xiàn),對于 Mock.mock(url,function(ops)) ,ops參數(shù)就可以拿到傳送的數(shù)據(jù)。
// 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', { // 添加數(shù)據(jù)的接口,數(shù)據(jù)為一個對象,有個title屬性 title: this.title }) }, getProjects () { axios.get('/mock/projects').then(res => { // 獲取數(shù)據(jù) console.log(res.data) }) } } } </script>
我們在mock.js中模擬一個添加數(shù)據(jù)的接口,拿到數(shù)據(jù)后存到數(shù)組中。
// mock.js // 添加信息 let projectList = [] Mock.mock('/mock/addProject', ops => { // 攔截ajax請求,調(diào)用函數(shù) console.log(ops) // 先看一下這個ops是什么 projectList.push(ops) }) // 獲取信息 Mock.mock('/mock/projects', projectList)
在輸入框中輸入標(biāo)題后,點擊提交,數(shù)據(jù)發(fā)送到/mock/addProject, mock.js
攔截到請求后,調(diào)用function(ops)方法,打印看到ops是個對象,有3個屬性,url,type和body,而我們輸入的數(shù)據(jù)就在body屬性值里,同時因為axios默認(rèn)發(fā)送的是json格式的數(shù)據(jù),所以body里面的數(shù)據(jù)是json串,更改function(ops)函數(shù),將數(shù)據(jù)以js對象的形式存入數(shù)組中。當(dāng)然實際開發(fā)中可以看后端的數(shù)據(jù)返回格式,選擇在前端進(jìn)行json轉(zhuǎn)js的操作,這里只是演示一下。
// mock.js // 添加信息 let projectList = [] Mock.mock('/mock/addProject', ops => { // 攔截ajax請求,調(diào)用函數(shù) // console.log(ops) // 先看一下這個ops是什么 ops = JSON.parse(ops.body) projectList.push(ops) }) // 獲取信息 Mock.mock('/mock/projects', projectList)
更改后輸入標(biāo)題,點擊提交,再點擊獲取,可以看到返回了我們提交的數(shù)據(jù),并且是js對象的形式,拿到數(shù)據(jù)后就可以做進(jìn)一步的操作了。
修改功能的代碼也是類似的。
刪除數(shù)據(jù)
刪除數(shù)據(jù)一般是把數(shù)據(jù)的id以get形式傳遞給后端,url形式為: /xxx/xxx?id=value, 實際開發(fā)中后端可以很好的處理id值不同的url,我們只需要關(guān)心怎么獲取到id,但是使用mock.js時,攔截的url我不知道怎么寫成動態(tài)的. Mock.mock('/mock/delete')
,此時使用axios.get()時就會報錯:
所以還是改成了用post傳遞的方式。
不知道是不是有什么別的方法,可以使得刪除時使用get請求。
總結(jié)
以上所述是小編給大家介紹的vue項目中mock.js的使用及基本用法,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對創(chuàng)新互聯(lián)網(wǎng)站的支持!
如果你覺得本文對你有幫助,歡迎轉(zhuǎn)載,煩請注明出處,謝謝!
本文標(biāo)題:vue項目中mock.js的使用及基本用法
文章位置:http://www.rwnh.cn/article48/pgcsep.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站排名、外貿(mào)網(wǎng)站建設(shè)、虛擬主機(jī)、網(wǎng)站改版、網(wǎng)站設(shè)計公司、用戶體驗
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)