json数据对接
1.前言
- fastadmin框架本身封装了一系列接口和插件来对表格数据进行管理(新增,编辑,删除),但是其使用的bootstrapTable基于jquery开发,基于某些原因,我们想要使用Vue框架代替bootstrapTable对页面进行渲染,但是会涉及参数的数据格式问题,此文对想一个的数据格式进行测试,方便后续使用
2.请求头
- 请求头要设定两个字段:content-type 和 X-Requested-With
const result = await this.$axios({
url:"/admin/sp/mcsparepart/add",
headers:{
"content-type": "application/x-www-form-urlencoded; charset=UTF-8",//数据格式申明
'X-Requested-With': 'XMLHttpRequest'
},
method:"post",
data:formData
})
3.参数的数据格式
vue中一般使用json数据,而fastadmin提供的接口使用的是表单数据格式,在转换过程中要注意两点:
- json和form两种格式区别如下:
var jsonData = {
key1:"1",key2:"2"
}
var formData = "key1=1&key2=2"
- 直接将json数据转换为表单字符串(用于get请求)
//将json数据转换成表单字符串
jsonToFormData(data){
var formData = ""
for(var key in data){
formData += `${key}=${data[key]}&`
}
//去除最后一个字母&
formData = formData.substring(0,formData.length-1)
return formData
}
- 将json数据转换成表单对象(用于post请求)
//创建新的表单
var form = new FormData()
//遍历json,给表单添加字段
for(var key in json){
form.append(`row[${key}]`,json[key])
}
//返回表单
return form
4.对接表格列表接口
- 表格列表接口的地址:页面地址
- 请求方式:get
- 需要设定请求头
headers:{
"content-type": "application/x-www-form-urlencoded; charset=UTF-8",//数据格式申明
'X-Requested-With': 'XMLHttpRequest'
}
- 基本参数(已解析视图):分页
offset: 10,limit: 10
- 搜索过滤参数(已解析视图):
//搜索字段的值(json字符串)
filter: "{downmenu_value: value}"
//模糊搜索(LIKE)还是精确搜索(=)
op: "{downmenu_value:'LIKE'}"
- 配合axios使用
//this.current_page当前页码
//this.page_size每页数量
//this.op字段搜索方式 {key:"Like",key2:"="}
//search_params搜索表单(过滤无数据的字段)
const result = await this.$axios({
url:"/admin/warehouse/warehouse",
headers:{
"content-type": "application/x-www-form-urlencoded; charset=UTF-8",//数据格式申明
'X-Requested-With': 'XMLHttpRequest'
},
params:{
offset: (this.current_page-1) * this.page_size,//跳过条数
limit: this.page_size,//获取条数
op: JSON.stringify(this.op),//字段搜索方式
filter: JSON.stringify(search_params),//搜索字段值
}
})
5.对接新增接口和编辑接口
- 新增接口的地址:页面地址 + /add?dialog=1
- 编辑接口的地址(ids为要编辑行的id):页面地址 + /edit/ids/"+ids
- 请求方式:post
- post参数:post参数表单格式,每个参数名称外面需要包裹一层row,例如:
//创建新的表单
var form = new FormData()
//遍历json,给表单添加字段
for(var key in json){
form.append(`row[${key}]`,json[key])
}
//返回表单
return form
6.对接删除接口
- 删除接口的地址:页面地址 + /del
- 请求方式:post
- post参数(指定action字段和ids字段,如果有多个id,则用逗号分割):action=del&ids=180
var formData = action=del&ids=180
const result = await this.$axios({
url:"/admin/sp/mcsparepart/del",
headers:{
"content-type": "application/x-www-form-urlencoded; charset=UTF-8",
'X-Requested-With': 'XMLHttpRequest'
},
method:"post",
data:formData
})
7.单独修改某个字段值
- 接口地址:页面地址 + /multi
- 请求方式:post
- 参数:
ids: 1
params: status=0
8.完整代码
- 获取表格数据
//发请求 获取表格数据
async getTableData(){
try {
//过滤出搜索表单没有值的字段
var search_params = {}
for(var key in this.form){
var value = this.form[key]
if(value){
search_params[key] = value
}
}
//表格加载状态
this.table_loading = true
//发请求
const result = await this.$axios({
url:"/admin/warehouse/warehouse",
headers:{
"content-type": "application/x-www-form-urlencoded; charset=UTF-8",//数据格式申明
'X-Requested-With': 'XMLHttpRequest'
},
params:{
offset: (this.current_page-1) * this.page_size,//跳过条数
limit: this.page_size,//获取条数
op: JSON.stringify(this.op),//字段搜索方式
filter: JSON.stringify(search_params),//搜索字段值
}
})
//表格加载状态
this.table_loading = false
//表格加载状态
this.tableData = result.data.rows || []
this.total = result.data.total
} catch (error) {
console.log(error)
//表格加载状态
this.table_loading = false
}
},
- 新增请求
//发请求 新增数据
async submitAdd(form){
try {
//提交loading状态
this.submit_loading = true
//发请求
const result = await this.$axios({
url:"/admin/warehouse/warehouse/add",
method:"post",
headers:{
"content-type": "application/x-www-form-urlencoded; charset=UTF-8",//数据格式申明
'X-Requested-With': 'XMLHttpRequest'
},
data:form
})
//提交loading状态
this.submit_loading = false
//处理返回结果
if (result.data.code == 1) {
//关闭弹窗
this.dialogVisible = false
//重置页码
this.current_page = 1
//刷新表格数据
this.getTableData()
} else {
this.$message.error(result.data.msg)
}
} catch (error) {
console.log(error)
//提交loading状态
this.submit_loading = false
}
},
- 编辑请求
async submitEdit(form){
try {
//提交loading状态
this.submit_loading = true
//发请求
const result = await this.$axios({
url:"/admin/warehouse/warehouse/edit/ids/" + this.edit_id,
method:"post",
headers:{
"content-type": "application/x-www-form-urlencoded; charset=UTF-8",//数据格式申明
'X-Requested-With': 'XMLHttpRequest'
},
data:form
})
//提交loading状态
this.submit_loading = false
//处理返回结果
if (result.data.code == 1) {
//关闭弹窗
this.dialogVisible = false
//重置页码
this.current_page = 1
//刷新表格数据
this.getTableData()
} else {
this.$message.error(result.data.msg)
}
} catch (error) {
console.log(error)
//提交loading状态
this.submit_loading = false
}
},
- 删除请求
//发请求 删除数据
async submitDelete(ids){
var formData = `action=del&ids=${ids}`
try {
this.table_loading = true
const result = await this.$axios({
url:"/admin/warehouse/warehouse/del",
method:"post",
data: formData,
headers:{
"content-type": "application/x-www-form-urlencoded; charset=UTF-8",//数据格式申明
'X-Requested-With': 'XMLHttpRequest'
}
})
this.table_loading = false
//处理返回结果
if (result.data.code == 1) {
//关闭弹窗
this.dialogVisible = false
//刷新表格数据
this.getTableData()
} else {
this.$message.error(result.data.msg)
}
} catch (error) {
console.log(error)
this.table_loading = false
}
}
json数据对接的更多相关文章
- 通过AngularJS实现前端与后台的数据对接(二)——服务(service,$http)篇
什么是服务? 服务提供了一种能在应用的整个生命周期内保持数据的方法,它能够在控制器之间进行通信,并且能保证数据的一致性. 服务是一个单例对象,在每个应用中只会被实例化一次(被$injector实例化) ...
- 格式化JSON数据
function formatJson(json, options) { var reg = null, formatted = '', pad = 0, PADDING = ' '; options ...
- C# 读取网页JSON数据
场景描述: 公司和别的系统需要对接,现在对方提供一个网址,数据都是json字符串,我需要对json数据进行处理. 提供的json数据如下格式 一.读取网址中的json数据 public string ...
- python 全栈开发,Day94(Promise,箭头函数,Django REST framework,生成json数据三种方式,serializers,Postman使用,外部python脚本调用django)
昨日内容回顾 1. 内容回顾 1. VueX VueX分三部分 1. state 2. mutations 3. actions 存放数据 修改数据的唯一方式 异步操作 修改state中数据的步骤: ...
- [系列] Go 如何解析 JSON 数据?
概述 最近掉进需求坑了,刚爬上来,评估排期出现了严重问题,下面三张图很符合当时的心境. 谈需求 估排期 开始干 为啥会这样,我简单总结了下: 与第三方对接. 跨团队对接. 首次用 Go 做项目. 业务 ...
- 数据对接:从Notion Database到低代码平台
前言 Notion简介 近几年,有一款叫Notion的产品异常火爆,它是集笔记.任务管理.Wiki.数据管理为一体的产品,他主打两个理念「模块化」和「All-in-one」,Notion最有魅力的还是 ...
- 使用TSQL查询和更新 JSON 数据
JSON是一个非常流行的,用于数据交换的文本数据(textual data)格式,主要用于Web和移动应用程序中.JSON 使用“键/值对”(Key:Value pair)存储数据,能够表示嵌套键值对 ...
- 通过AngularJS实现前端与后台的数据对接(一)——预备工作篇
最近,笔者在做一个项目:使用AngularJS,从而实现前端与后台的数据对接.笔者这是第一次做前端与后台的数据对接的工作,因此遇到了许多问题.笔者在这些问题中,总结了一些如何实现前端与后台的数据对接的 ...
- 利用Python进行数据分析(2) 尝试处理一份JSON数据并生成条形图
一.JSON 数据准备 首先准备一份 JSON 数据,这份数据共有 3560 条内容,每条内容结构如下: 本示例主要是以 tz(timezone 时区) 这一字段的值,分析这份数据里时区的分布情况. ...
- Salesforce Apex 使用JSON数据的示例程序
本文介绍了一个在Salesforce Apex中使用JSON数据的示例程序, 该示例程序由以下几部分组成: 1) Album.cls, 定了了封装相关字段的数据Model类 2) RestClient ...
随机推荐
- [C++] Rander
注 这个Rander对单个数据的平均分散不太优秀,但是获取大量数据十分平均 当前版本 2.0 for Windows 功能 int rander::reset() 按默认大小重置随机数序列,返回默认大 ...
- 第6天:基础入门-抓包技术&HTTPS协议&APP&小程序&PC应用&WEB&转发联动
安装charles 到Windows本地: 安卓模拟器安装: 如果抓模拟器就要使用从远程主机,如果不是,则从所有进程 访问 谷歌浏览器安装证书: PC微信小程序代理抓取: 41:43 :如何将char ...
- WordPress产品分类添加,自动排序插件
效果图如下 目前这个预览菜单这个效果有点问题,但是不影响实际排序,有懂源码的朋友可以自行修改一下,目录结构menu -assets menu.css menu.js menu.php 源码如下menu ...
- 关于Android Q平台上qssi的介绍
QSSI 是 Qualcomm Single System Image 的缩写. Android Q上开始支持QSSI. QSSI 是用来编译system.img的3.1 QSSI编译注意事项 lun ...
- markdown.css 设置文章的样式
返回的详情文章内容是标签加内容文字,使用 markdown,css 渲染样式 : .markdown-body .octicon { display: inline-block; fill: curr ...
- 18 . 介绍一下 Promise
Promise 是js内置的构造函数,也叫做期约函数 ,它有 3 种状态 ,等待状态 pending ,成功状态 fullfilled ,失败状态 reject :2 个过程, 等待状态到成功状态 会 ...
- kotlin类与对象——>对象表达式与对象声明、内联类
1.对象表达式与对象声明 有时候,我们需要创建一个对某个类做了轻微改动的类的对象,而不用为之显式声明新的子类.Kotlin 用对象表达式和对象声明处理这种情况 2.对象表达式 要创建一个继承自某个(或 ...
- 妙用编辑器:使用Notepad--宏功能提高维护指令生成生成效率
应用场景 日常维护工作中,需要快速生成一批指令来完成某些操作,比如:快速添加一批节点. 目标指令列表如下: ADD NODE: ID=1, NAME="NODE_1"; ADD N ...
- 云原生周刊:KubeSphere 宣布开源 Thanos 的企业级发行版 Whizard
开源项目推荐 Admiralty Admiralty 是一个 Kubernetes 控制器系统,可以智能地在多个集群之间调度工作负载.它使用简单,并且易于与其他工具集成. Cozystack Cozy ...
- 云原生周刊:Gateway API 1.0.0 发布 | 2023.11.6
开源项目推荐 Kueue Kueue 是一套用于作业队列的 API 和控制器.它是作业级管理器,可决定何时允许作业启动(如创建 pod),何时停止作业(如删除活动 pod). Reloader 一个 ...