umi request和mock(mock文件夹下的js文件)请求传递和接收参数

1 篇文章 0 订阅

目录

utils/request.js

services/test.js

mock/test.js

拓展


utils/request.js

const fetch = require('dva').fetch;

const checkStatus = response => {
  if (response.status == 200) return response;
  throw { message: 'error' };
};
const parseJson = response => {
  const { statusText, status } = response;
  return response.json().then(res => {
    console.log('parsejson.res', res);
    return {
      data: res,
      status,
      success: true,
    };
  });
};
// 请求头需要加上,不然post请求,mock里接收不到参数
const headers = {
  'Accept': 'application/json',
  'Content-Type': 'application/json'
};
export default (url, options) => {
  return fetch(url, {...options, headers})
    .then(checkStatus)
    .then(parseJson);
};

  

services/test.js

get和delete请求传参形式相同

post和put请求传参形式相同

import request from '../utils/request';
var qs = require('qs');

export const getBrand = params => {
    console.log('getBrand', { ...params });
    // get请求传参,参数要拼接在url后面
    // 此处的“ ? ”一定要加上
    // qs.stringify()会将参数转成 a='1'&b='2' 的形式,如果不使用qs库可手动转换
    return request('/api/brand?' + qs.stringify(params), {
        method: 'GET',
    });
};

export const deleteBrand = params => {
    // 同get请求
    return request('/api/brand?' + qs.stringify(params), {
        method: 'DELETE'
    })
}

export const updateBrand = params => {
    // post请求
    return request(`/api/brand`, {
        // 此处一定要JSON格式化,不然mock里同样接收不到数据
        body: JSON.stringify(params),
        method: 'POST',
    })
}

mock/test.js

get请求接收参数用 req.query

post请求接收参数用 req.body

如果接收不到参数,要么没格式化数据,要么没加请求头;get和delete请求则还可能是“ ? ”没加

export default {
    'GET /api/brand': (req, res) => {
        /**
         * get请求接收参数用req.query
         * 接收url后的字符串解析出来的对象
         * username=zhangsan&password=123 { username:zhangsan }
         */
        let data = getBrandList(req.query);
        res.status(200).json(data);
    },

    'POST /api/brand': (req, res) => {
         /**
         * post请求接收参数用req.body
         */
        const { record } = req.body;
        updateBrand(record);
        res.json(200);
    }
};

拓展

response和request参数的说明 链接(文章最下面的续篇):dva中对于mock的简单使用(另附umi中的使用方法和自己手动fetch发送请求方法,还有mock中response和request参数的配置)

Request
    req.baseUrl 基础路由地址
    req.body post发送的数据解析出来的对象
    req.cookies 客户端发送的cookies数据
    req.hostname 主机地址 去掉端口号
    req.ip 查看客户端的ip地址
    req.ips 代理的IP地址
    req.originalUrl 对req.url的一个备份
    req.params 在使用/:id/:name 匹配params
    req.path 包含请求URL的路径部分
    req.protocol http 或https协议
    req.query 查询字符串解析出来的对象 username=zhangsan&password=123 { username:zhangsan }
    req.route 当前匹配的路由 正则表达式
    req.params 获取路由匹配的参数
    req.get 获取请求header里的参数
    req.is 判断请求的是什么类型的文件
    req.param(key名称) 用来获取某一个路由匹配的参数
 
 
Response
    res.headersSent 查看http响应是否响应了http头
    res.append(名称,value) 追加http响应头
    res.attachment(文件路径) 响应文件请求 
    res.cookie() 设置cookie
    
    res.setHeader('Content-Type','text/html;charset=utf8')
    res.append('Content-Type','text/html;charset=utf8')
    res.append('hehe','1008')
    res.append('haha','1008')
    res.attachment('./xx.zip') //Content-Disposition: attachment; filename="xx.zip"
    res.clearCookie(cookiename) 删除cookie
    res.cookie('zhangsan','lisi') 设置cookie
    res.cookie('zhangsan1','lisi2',{
        maxAge:900000,
        httpOnly:true,
        path: '/admin', 
        secure: true,
        signed:true
    })
    res.clearCookie('zhangsan')
 
    res.download(文件的path路径) 跟attachment类似 用来处理文件下载的 参数是文件地址
    res.end http模块自带的
    res.format()协商请求文件类型 format匹配协商的文件类型
    res.format({
        'text/plain': function(){
            res.send('hey');
        },
        
        'text/html': function(){
            res.send('<p>hey</p>');
        },
        
        'application/json': function(){
            res.send({ message: 'hey' });
        },
        
        'default': function() {
            // log the request and respond with 406
            res.status(406).send('Not Acceptable');
        }
    });
 
    res.get('key') 获取响应header数据
    res.json() 返回json数据 会自动设置响应header Content-type 为json格式 application/json
 
    res.json({
        xx:100
    })
 
    res.json({
        xx:100
    })
 
    jsonp 利用的就是浏览器加载其他服务器的文件不会存在跨域问题
    ajax请求就会有跨域问题
 
    res.setHeader('Content-Type','text/javascript;charsert=utf8')
    res.end(`typeof ${req.query.callback} == 'function' ? ${req.query.callback}({aa:100}):null`)
 
    res.jsonp({aaa:100})
 
 
    重定向 把访问的地址跳转到另一个地址上
    res.redirect(301,'/api/aes')
 
    express jade
    res.render('index',{title:"hehe",test:"23"})
    res.send('') 发送数据 可以是任意类型的数据
    res.sendFile() 发送文件的 
    res.sendStatus(200) 设置发送时的状态码
    res.set('Content-Type', 'text/plain') //设置响应header
    res.status(200) // 设置状态码
    res.type('') // 直接设置响应的文件类型
 
    res.type('pdf')
 
    res.send({aa:100})
    res.end('ok')
    res.end({aa:100})
 
    res.end('你好')
 
 
    res.end(req.get('Accept-Language'))
    res.json({
        is:req.is('text/html')
    })
 
    res.json({
        type:req.baseUrl,
        hostname:req.hostname,
        // ip:req.ip,
        // ips:req.ips,
        // route:req.route,
        ct:req.get('Accept'),
        cs:'22'
    })

 

  • 0
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
umi中使用mock传参的方法如下: 1. 首先,需要在src目录下创建一个api文件夹,用来管理整个项目的接口数据。在api文件夹下创建index.js文件作为入口请求文件。 2. 导入Mock模块:`const Mock = require('mockjs');` 3. 使用Mock.mock()方法来模拟请求数据。例如,如果想模拟一个GET请求传递参数,可以使用以下代码: ``` Mock.mock('/api/brand', 'get', function (options) { // 通过options.body获取传递参数 const { brandId } = JSON.parse(options.body); // 进行相应的处理,返回模拟的数据 return Mock.mock({ status: 200, message: '请求成功', data: { brandId: brandId, brandName: '@cname', }, }); }); ``` 4. 通过以上步骤,就可以在umi中使用mock传递参数了。 需要注意的是,在使用POST请求传递参数时,需要将参数进行JSON格式化,然后将其作为body传递mock的接口。 参考文献: 一般情况是在src文件夹下创建api文件夹,用来管理整个项目的接口数据,然后我们需要接着在api文件夹下创建index.js,作为入口请求文件 const Mock = require('mockjs'); //格式: Mock.mock( url, post/get , 返回的数据); 下面的userInfo是指mock目录下的json目录下的userInfo.json文件 Mock.mock('/user/userInfo', 'get', require('./json/userInfo.json')); Mock.mock('/api/addgoods', 'post', require('./json/userInfo.json')); // 下边这个模拟post请求也行 /*Mock.mock('/api/addgoods', 'post', function (option) { let $name=JSON.parse(option.body).name; if($name){ return Mock.mock({ status: 200, message: '提交成功!!!' }) }else{ return Mock.mock({ status: 400, message: '未提交参数' }) } })*/ 引用:post和put请求传参形式相同 import request from '../utils/request'; var qs = require('qs'); export const getBrand = params => { console.log('getBrand', { ...params }); // get请求传参,参数要拼接在url后面 // 此处的“ ? ”一定要加上 // qs.stringify()会将参数转成 a='1'&b='2' 的形式,如果不使用qs库可手动转换 return request('/api/brand?' qs.stringify(params), { method: 'GET', }); }; export const deleteBrand = params => { // 同get请求 return request('/api/brand?' qs.stringify(params), { method: 'DELETE' }) } export const updateBrand = params => { // post请求 return request(`/api/brand`, { // 此处一定要JSON格式化,不然mock里同样接收不到数据 body: JSON.stringify(params), method: 'POST', }) } mock/test.js 。 引用:使用方法如下: 1、安装mockjs npm install mockjs 2、在vue项目中mock创建文件夹 。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *3* [Vue中使用Mock模拟get和post请求](https://blog.csdn.net/efew212efe/article/details/124493618)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* [umi requestmockmock文件夹下的js文件请求传递接收参数](https://blog.csdn.net/weixin_41786574/article/details/107759491)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值