当前位置: 首页 > wzjs >正文

美食网站开发与设计文献综述百度云资源搜索

美食网站开发与设计文献综述,百度云资源搜索,wordpress漏洞改密码,福田网站建设龙岗网站建设罗湖网站建设罗湖网站建设前言 小程序自带的网络请求使用起来比较麻烦,不便于管理,就需要封装网络请求,减少繁琐步骤,封装最终效果,根据类别将网络请求封装在文件中,使用得时候调用文件名名称加文件中得自定义名称,就可…

前言

小程序自带的网络请求使用起来比较麻烦,不便于管理,就需要封装网络请求,减少繁琐步骤,封装最终效果,根据类别将网络请求封装在文件中,使用得时候调用文件名名称加文件中得自定义名称,就可以了

需要vue2+Axios封装网络请求的点这里
需要vue3+ts+Axios封装网络请求的点这里

安装Axios

 npm install axios或者yarn add axios

新建network网络请求文件

在这里插入图片描述
index.js:网络请求文件
config.js:自动导入apis文件夹下的所有js文件,需要把apis文件下的文件名写进去
home.js:自定义文件名称,根据自己请求类别进行分类,比home,购物车,等等

index.js 文件

import config from "./config";
// 定义函数完成网络请求
function startNetwork(params) {return new Promise((resolve, reject) => {uni.request({...params,success(res) {resolve(res);if (res.code != 0) {reject(res.msg);}else {resolve(res);}},fail: () => {reject('网络请求失败!');}})});
}
const files = config.files;
//完成文件名称的提取并且将对应文件中的模块数据进行导入
const modules = files.reduce((target, filePath) => {const fileName = filePath.replace(/^(\w+)\.(js)$/i, "$1");const module = require("./apis/" + filePath);for (let key in module) {target[fileName + "/" + key] = module[key];}return target;
}, {});//设置代理数据完成对modules对象的数据拦截
const proxy = new Proxy(modules, {async get(target, key) {const params = target[key](target.meta ? target.meta : null);const res = await startNetwork(params);target.meta = null;return res;}
});//定义函数完成网络数据的获取
async function getDatas(keyName, meta = null) {if (meta) {proxy.meta = meta;}return await proxy[keyName];
}export default getDatas;

config.js文件

把apis文件夹下的名称导入,就不用一个一个导入index.js页面了

export default {files:["home.js",]
}

home.js文件

Header部分这里是我的Header,用的时候替换自己的就可以了

var md5 = require("../../utils/md5.js");
function getHeader() {var timestamp = Date.parse(new Date());timestamp = parseInt(timestamp / 1000);let herder_info = {"content-type": "application/json", // 默认值"access-token": getToken(),"access-sign": md5.hexMD5(timestamp + "c-q-z-n") + "." + timestamp,};return herder_info;
}
const getToken = function () {var token = uni.getStorageSync("token");return token;
};module.exports = {xuqiuInfo(mate) {  //网络请求名称,一个文件中名称不可重复return {method: "GET",url: "",//放入你自己的真实的请求地址header: getHeader(),data: mate,};},xuqiuSave(mate) { //网络请求名称,一个文件中名称不可重复return {method: "POST",url:  "",//放入你自己的真实的请求地址header: getHeader(),data: mate,};},
};

main.js文件中全局导入

import getDatas from './static/network/index.js'
//完成网络请求的全局挂载 
Vue.prototype.$axios = getDatas

使用方式

home:apis文件下的文件名称
xuqiuSave:home.js文件中的网络请求名称,
然后将网络请求写成对应得函数即可,使用时候调用对应得函数,就可以调用网络请求,使用得时候只需要调用该文件下的对应得请求即可进行网络请求

携带参数

      async xuqiuSave() {const res = await this.$axios("home/xuqiuSave", {title: this.search,status: '',//状态(留空查询全部,0禁用1正常)types: '',// 客户分类id (留空查询全部)page: this.currentPage,//页码limit: '',//每页数量});console.log("xuqiuSave", JSON.parse(JSON.stringify(res.data)));},

不携带参数

      async xuqiuInfo() {const res = await this.$axios("home/xuqiuInfo");console.log("xuqiuInfo", JSON.parse(JSON.stringify(res.data)));},
http://www.dtcms.com/wzjs/350614.html

相关文章:

  • 广州个人网站建设培训心得体会范文大全1000字
  • 个人简约网站模板seo排名优化厂家
  • 婴幼儿网站模板企业如何建站
  • 利用帝国软件如何做网站seo知识分享
  • 南昌百度网站快速排名百度推广技巧方法
  • 贵港做网站化司关键词搜索排名优化
  • 重庆网站建设套餐流程优化
  • 朋友圈网站文章怎么做桂平网络推广
  • 南充网站建设化工网站关键词优化
  • 源代码网站和模板做的区别免费b站推广软件
  • 宁波网站开发百度指数如何分析
  • 为什么做的网站在浏览器搜不到沈阳网站推广优化
  • 图片怎么做网站背景怎么建立网站的步骤
  • 给国外做网站最近实时热点新闻事件
  • 豪华大气的旅行社网站源码沈阳seo排名优化教程
  • 西安网站制作的公司百度seo运营工作内容
  • 深圳做网站网络公司北京网络推广公司wyhseo
  • 用dw做的网站容易变形湖南网站seo找行者seo
  • 网站建设销售问你告诉我怎么制作中国站长之家网站
  • 做品牌特卖的网站手机网站百度关键词排名
  • 十种人不适合学建筑seo狂人
  • asp net mvc做网站如何刷关键词指数
  • 做兼职那个网站靠谱吗站长工具综合权重查询
  • 做网站番禺如何创建自己的网站
  • 网站开发美学seo外链建设的方法有
  • 做网站按什么收费多少钱搜索关键词排名优化
  • 网站怎么做关键词搜索排面搜索
  • 赣州建设网站公司广州头条新闻最新
  • 餐饮品牌推广方案杭州关键词推广优化方案
  • 网站联盟系统站长工具网