uin-app+mockjs實現本地數據模擬

    最近在開發項目的時候,需要用到mockjs這個包來實現前端本地數據的模擬,下面我就來說一下具體步驟:

    前言

    uni-app將自己的配置融合到了vue.config.js中,所以需要自己配置,需要在package.json的同級目錄下新建一個vue.config.js;ajax請求的路由,因為這個路由我們希望拿到模擬數據,所以用webpack的devserve來攔截。愛掏網 - it200.com攔截之后通過mockjs,由它來生成模擬數據,然后返回模擬值。愛掏網 - it200.com

    步驟

    在vue.config.js中加入下面代碼:

    const Mock = require('./mock/index.js');
    module.exports = {
     chainWebpack: (config) => {  
      config.resolve.alias
      .set( '@',resolve(__dirname, '/'))//設置@為src目錄的別名)
     },
     css: {
      ....
      }
    
     },
     devServer: {
      contentBase: path.join(__dirname, 'mock'),
      compress: true,
      port: 8080,
      overlay: {
       warnings: false,
       errors: true
      },
      before(app){
       Mock(app)
      }
    }
    };

    devserver的配置中的before配置項是攔截路由請求。愛掏網 - it200.com我們把全部交給Mock(app)處理;然后打開mock/index.js寫入如下代碼:

    const addressesMock = require('./addresses');
    const attendanceMock = require('./attendance');
    const attendanceListMock = require('./attendance-list');
    ....
    function Mock(app) {
     addressesMock(app)
     attendanceMock(app)
     attendanceListMock(app)
     .....
    }
    
    module.exports = Mock;

    打開addresses寫入你需要mock的數據就ok啦

    var Mockjs = require('mockjs')
    const { Random }= Mockjs;
    const phOnePrefix= ['132', '135', '189']
    const index = Math.floor(Math.random() * phonePrefix.length)
    var phOne= phonePrefix[index] + Mockjs.mock(/\d{8}/)
    const addressesMock = function (app) {
      app.get('/api3/addresses', function(req, res) {
       var data = Mockjs.mock({
        // 屬性 list 的值是一個數組,其中元素的數量從 1 到 10 個都有可能,隨機
        'list|1-10': [{
         'id|+1': 0,
         "accept_name": Random.cname(),
         "mobile": phone,
         "province_name": Random.province(),
         "area": Mockjs.mock(/\d{6}/),
         "city": Mockjs.mock(/\d{6}/),
         "sex": parseInt(Random.boolean()),
         "district": {
          "districts": Random.province()+Random.city()+Random.county(),
          "area": Random.county(),
          "city": Random.city(),
          "province": Random.province()
         },
         "street": "有一間公寓八棟",
         "inner": false,
         "lat": "",
         "door_number": "AB1234",
         "is_default": parseInt(Random.boolean()),
         "province": Mockjs.mock(/\d{6}/),
         "area_name":Random.county(),
         "city_name": Random.city(),
         "poiname": ""
        }]
       })
       res.json(data);
      })
     }
     
    module.exports = addressesMock;

    在需要接口的地方之間用 就能得到相應數據了

    this.$ajax.get('/api3/addresses').then(res => { // 調用接口
          })

    以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持。愛掏網 - it200.com


    聲明:所有內容來自互聯網搜索結果,不保證100%準確性,僅供參考。如若本站內容侵犯了原著者的合法權益,可聯系我們進行處理。
    發表評論
    更多 網友評論0 條評論)
    暫無評論

    返回頂部

    主站蜘蛛池模板: 在线电影一区二区三区| 精品国产一区AV天美传媒| 日本无卡码免费一区二区三区| 国模私拍一区二区三区| 久久一区二区精品| 日韩在线视频一区二区三区| 久99精品视频在线观看婷亚洲片国产一区一级在线 | 国产主播一区二区| 在线精品日韩一区二区三区| 久久久综合亚洲色一区二区三区| 影院成人区精品一区二区婷婷丽春院影视| 精品国产一区二区麻豆| 免费无码VA一区二区三区| asmr国产一区在线| 无码AⅤ精品一区二区三区| 精品成人乱色一区二区| 久久4k岛国高清一区二区| 清纯唯美经典一区二区| 一区二区三区在线|日本| 视频在线观看一区二区| 午夜视频一区二区| 日韩一区二区三区不卡视频| 日韩精品无码免费一区二区三区| 国产午夜精品一区理论片飘花| 精品国产一区二区三区久久狼| 爆乳无码AV一区二区三区| 一区二区三区视频| 国产精品资源一区二区| 国产精品盗摄一区二区在线| 精品一区二区ww| 杨幂AV污网站在线一区二区| 精品一区二区三区高清免费观看| 日韩av片无码一区二区三区不卡| 一区二区三区精品视频| 国精无码欧精品亚洲一区| 亚洲天堂一区在线| 国产一区二区影院| 国产爆乳无码一区二区麻豆 | 波多野结衣中文字幕一区| 久久久人妻精品无码一区 | 久久亚洲AV午夜福利精品一区|