IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 开发测试 -> antd仿postman(10) -> 正文阅读

[开发测试]antd仿postman(10)

一、demo代码

body tab页下,选择不同的radio展示不同的页面:

<a-radio-group defaultValue="none" :select="body_type" name="radioGroup" @change="onChange" style="width: 100%" >
  <a-radio value="none">none</a-radio>
  <a-radio value="form-data">form-data</a-radio>
  <a-radio value="x-www-form-urlencoded">x-www-form-urlencoded</a-radio>
  <a-radio value="raw">raw</a-radio>
  <a-radio value="binary">binary</a-radio>
  <a-radio value="GraphQL">GraphQL</a-radio>
  <a-card style="width: 100%" >
    <p  v-if="body_type=='none'">This request does not have a body</p>
    <div v-else-if="body_type=='form-data'">
      <a-table :columns="columns" :dataSource="data" :pagination="false" bordered>
        <template v-for="col in ['KEY', 'VALUE', 'DESCRIPTION']" :slot="col" slot-scope="text, record, index">
          <div :key="col">
            <a-input
                v-if="record.editable"
                style="margin: -5px 0"
                :value="text"
                @change="e => handleChanged(e.target.value, record.key, col,index)"
            />
            <template v-else>{{text}}</template>
          </div>
        </template>
        <template slot="operation" slot-scope="text, record, index">
          <div class='editable-row-operations'>
    <span v-if="record.editable">
      <a-space>
      <a @click="() => save(record.key,index)">Save</a>
      <a-popconfirm title='Sure to cancel?' @confirm="() => cancel(record.key,index)">
        <a>Cancel</a>
      </a-popconfirm>
      </a-space>
    </span>
            <span v-else>
      <a @click="() => edit(record.key,index)">Edit</a>
    </span>
          </div>
        </template>
      </a-table>
      <a-button class="editable-add-btn" style="width: 100%" @click="handleAdd">+ 添加一行数据</a-button>
    </div>
    <codemirror v-else
        ref="myCmGenerate"
        class="code-mirror"
        v-model="code"
        :options="options"
        @changes="changes"
        @ready="onCmReady"
        @focus="onCmFocus"
        @input="onCmCodeChange"
        @scroll="onScrollFn"
    />
  </a-card>
</a-radio-group>

二、完整代码

<template>
<div>
  <a-card title="在线HTTP测试工具" style="width: 100%">
    <a-row>
      <a-col :span="4">
        <a-space>
          <a-select
              ref="select"
              defaultValue="get"
              style="width: 150px"
              @focus="focus"
              @change="handleChange"
          >
            <a-select-option value="get">GET</a-select-option>
            <a-select-option value="post">POST</a-select-option>
            <a-select-option value="put" >PUT</a-select-option>
            <a-select-option value="delete">DELETE</a-select-option>
          </a-select>
        </a-space>
      </a-col>
      <a-col :span="20">
       <a-input  style="width: calc(100% - 250px)" />
        <a-space>
            <a-button type="primary" @click="onSubmit" >请求此API</a-button>
            <a-popconfirm
                title="确定将请求转为case?"
                ok-text="确定"
                cancel-text="取消"
                @confirm="confirm"
                @cancel="cancel"
            >
              <a-button type="primary" >保存为case</a-button>
            </a-popconfirm>
        </a-space>
      </a-col>
    </a-row>
    <br />
    <a-row>
      <a-col :span="24">
        <!--       activeKey属性通过“v-model”实现表单与data数据的双向绑定, 需在data中定义该属性-->
        <a-tabs v-model="activeKey">
          <a-tab-pane key="1" tab="Params">
            <a-table :columns="columns" :dataSource="data" :pagination="false" bordered>
              <template v-for="col in ['KEY', 'VALUE', 'DESCRIPTION']" :slot="col" slot-scope="text, record, index">
                <div :key="col">
                  <a-input
                      v-if="record.editable"
                      style="margin: -5px 0"
                      :value="text"
                      @change="e => handleChanged(e.target.value, record.key, col,index)"
                  />
                  <template v-else>{{text}}</template>
                </div>
              </template>
              <template slot="operation" slot-scope="text, record, index">
                <div class='editable-row-operations'>
                  <span v-if="record.editable">
                    <a-space>
                    <a @click="() => save(record.key,index)">Save</a>
                    <a-popconfirm title='Sure to cancel?' @confirm="() => cancel(record.key,index)">
                      <a>Cancel</a>
                    </a-popconfirm>
                    </a-space>
                  </span>
                  <span v-else>
                    <a @click="() => edit(record.key,index)">Edit</a>
                  </span>
                </div>
              </template>
            </a-table>
            <a-button class="editable-add-btn" style="width: 100%" @click="handleAdd">+ 添加一行数据</a-button>
          </a-tab-pane>
          <a-tab-pane key="2" tab="Headers" force-render>
            <a-table :columns="columns" :dataSource="data" :pagination="false" bordered>
              <template v-for="col in ['KEY', 'VALUE', 'DESCRIPTION']" :slot="col" slot-scope="text, record, index">
                <div :key="col">
                  <a-input
                      v-if="record.editable"
                      style="margin: -5px 0"
                      :value="text"
                      @change="e => handleChanged(e.target.value, record.key, col,index)"
                  />
                  <template v-else>{{text}}</template>
                </div>
              </template>
              <template slot="operation" slot-scope="text, record, index">
                <div class='editable-row-operations'>
                  <span v-if="record.editable">
                    <a-space>
                    <a @click="() => save(record.key,index)">Save</a>
                    <a-popconfirm title='Sure to cancel?' @confirm="() => cancel(record.key,index)">
                      <a>Cancel</a>
                    </a-popconfirm>
                    </a-space>
                  </span>
                  <span v-else>
                    <a @click="() => edit(record.key,index)">Edit</a>
                  </span>
                </div>
              </template>
            </a-table>
            <a-button class="editable-add-btn" style="width: 100%" @click="handleAdd">+ 添加一行数据</a-button>
          </a-tab-pane>
          <a-tab-pane key="3" tab="Body">
            <a-col :span="24">
              <a-radio-group defaultValue="none" :select="body_type" name="radioGroup" @change="onChange" style="width: 100%" >
                <a-radio value="none">none</a-radio>
                <a-radio value="form-data">form-data</a-radio>
                <a-radio value="x-www-form-urlencoded">x-www-form-urlencoded</a-radio>
                <a-radio value="raw">raw</a-radio>
                <a-radio value="binary">binary</a-radio>
                <a-radio value="GraphQL">GraphQL</a-radio>
                <a-card style="width: 100%" >
                  <p  v-if="body_type=='none'">This request does not have a body</p>
                  <div v-else-if="body_type=='form-data'">
                    <a-table :columns="columns" :dataSource="data" :pagination="false" bordered>
                      <template v-for="col in ['KEY', 'VALUE', 'DESCRIPTION']" :slot="col" slot-scope="text, record, index">
                        <div :key="col">
                          <a-input
                              v-if="record.editable"
                              style="margin: -5px 0"
                              :value="text"
                              @change="e => handleChanged(e.target.value, record.key, col,index)"
                          />
                          <template v-else>{{text}}</template>
                        </div>
                      </template>
                      <template slot="operation" slot-scope="text, record, index">
                        <div class='editable-row-operations'>
                  <span v-if="record.editable">
                    <a-space>
                    <a @click="() => save(record.key,index)">Save</a>
                    <a-popconfirm title='Sure to cancel?' @confirm="() => cancel(record.key,index)">
                      <a>Cancel</a>
                    </a-popconfirm>
                    </a-space>
                  </span>
                          <span v-else>
                    <a @click="() => edit(record.key,index)">Edit</a>
                  </span>
                        </div>
                      </template>
                    </a-table>
                    <a-button class="editable-add-btn" style="width: 100%" @click="handleAdd">+ 添加一行数据</a-button>
                  </div>
                  <codemirror v-else
                      ref="myCmGenerate"
                      class="code-mirror"
                      v-model="code"
                      :options="options"
                      @changes="changes"
                      @ready="onCmReady"
                      @focus="onCmFocus"
                      @input="onCmCodeChange"
                      @scroll="onScrollFn"
                  />
                </a-card>
              </a-radio-group>
            </a-col>
          </a-tab-pane>
          <a-tab-pane key="4" tab="Assert">
            <codemirror
                ref="myCmGenerate"
                class="code-mirror"
                v-model="code"
                :options="options"
                @changes="changes"
                @ready="onCmReady"
                @focus="onCmFocus"
                @input="onCmCodeChange"
                @scroll="onScrollFn"
            />
          </a-tab-pane>
        </a-tabs>
      </a-col>
    </a-row>
    <br />
    <a-row>
      <a-card title="Response" style="width: 100%">
        <p>{{ rev_data }}</p>
      </a-card>
    </a-row>
  </a-card>

</div>
</template>

<script>
import { codemirror } from 'vue-codemirror' // 引入组件
// 核心样式
import 'codemirror/lib/codemirror.css'

// 引入主题后还需要在 options 中指定主题才会生效
import 'codemirror/theme/material.css'

//设置代码编译类型,并在配置中设置指定项 mode
import 'codemirror/mode/python/python.js'
import 'codemirror/mode/javascript/javascript'
import {postman_send} from "@/services/postman";


//表头数据,title 为表头的标题 dataIndex为列数据在数据项中对应的 key
const columns = [
  {
    title : 'KEY',
    dataIndex: 'KEY',
    scopedSlots: { customRender: 'KEY' },
    width: '25%',
  },
  {
    title: 'VALUE',
    dataIndex: 'VALUE',
    scopedSlots: { customRender: 'VALUE' },
    width: '25%',
  },
  {
    title: 'DESCRIPTION',
    dataIndex: 'DESCRIPTION',
    scopedSlots: { customRender: 'DESCRIPTION' },
    width: '25%',
  },
  {
    title : 'operation',
    dataIndex: 'operation',
    scopedSlots: { customRender: 'operation' }, //值跟dataIndex对应,支持操作列插槽
    width: '25%',
  },
];


export default {
  name: "Postman",
  data() {
    return {
      api_url: "http://localhost:7777/auth/hello",
      rev_data: "",
      activeKey: '1',  //控制标签页params、headers、body
      data:[],
      dataSource:[],
      columns:columns,
      body_type:'none',
      editableData:{},
      code: '', // 编辑器绑定的值,对应v-model
      // 默认配置
      options: {
        tabSize: 4, // 缩进格式
        theme: 'material', // 主题,对应主题库 JS 需要提前引入
        lineNumbers: true, // 显示行号
        line: true,        // 检查格式
        autocorrect: true,  // 自动更正
        spellcheck: true,  // 拼写检查
        mode: { // 模式, 可查看 codemirror/mode 中的所有模式,运行代码类型
          name: 'python',
          json: true
        },
        styleActiveLine: true, // 高亮选中行
        hintOptions: {
          completeSingle: true // 当匹配只有一项的时候是否自动补全
        },
      }
    }
  },
  methods: {
    onSubmit() {
      this.loading = true;
      //TODO url,method,body,header等都需要传给后端
      postman_send(this.api_url)
          .then((result) => {
            this.loading = false;
            this.rev_data = result;
          })
          .catch((err) => {
            this.rev_data = err;
          });
    },
    focus(key) {
      console.log(key)
    },
    handleChange(key) {
      console.log(key)
    },
    onChange(e){
      //TODO json需要单独处理
      if (e.target.value === 'none') {
        this.body_type = 'none'
        console.log('radio-----',e)
      } else if (e.target.value === 'form-data') {
        this.body_type = 'form-data'
      } else if (e.target.value === 'x-www-form-urlencoded') {
        this.body_type = 'x-www-form-urlencoded'
      } else if (e.target.value === 'raw') {
        this.body_type = 'raw'
      }
    },
    onCmReady() {
      this.$refs.myCmGenerate.codemirror.setSize('100%', '600px')  //editor.setSize(width,height)
    },
    onCmFocus(instance, event) {
      console.log(instance,event)
    },
    onCmCodeChange(instance, obj) {
      console.log(instance,obj)
    },
    changes() {},
    onScrollFn() {},
    confirm() {},
    handleChanged (value, key, column, index) {
      const newData = [...this.data]
      const target = newData.filter(item => key === item.key)[index]
      if (target) {
        target[column] = value
        this.data = newData
      }
    },
    edit(key,index) {
      const newData = [...this.data]
      console.log('newData----',newData)
      const target = newData.filter(item => key === item.key)[index]
      if (target) {
        target.editable = true
        this.data = newData
      }
    },
    save(key,index) {
      const newData = [...this.data]
      const target = newData.filter(item => key === item.key)[index]
      if (target) {
        delete target.editable
        this.data = newData
        this.cacheData = newData.map(item => ({ ...item }))
      }
    },
   cancel(key,index) {
     const newData = [...this.data]
     const target = newData.filter(item => key === item.key)[index]
     if (target) {
       Object.assign(target, this.cacheData.filter(item => key === item.key)[index])
       delete target.editable
       this.data = newData
     }
    },
    handleAdd() {
      const { count } = this
      this.data.push( {
        KEY: '',
        VALUE: '',
        DESCRIPTION: '',
      })
      this.count = count + 1
    },
  },
  components: {
    codemirror
  },
}


</script>

<style scoped>

</style>

三、效果

在这里插入图片描述
在这里插入图片描述

四、遗留问题

重复组件未封装,代码冗余

  开发测试 最新文章
pytest系列——allure之生成测试报告(Wind
某大厂软件测试岗一面笔试题+二面问答题面试
iperf 学习笔记
关于Python中使用selenium八大定位方法
【软件测试】为什么提升不了?8年测试总结再
软件测试复习
PHP笔记-Smarty模板引擎的使用
C++Test使用入门
【Java】单元测试
Net core 3.x 获取客户端地址
上一篇文章      下一篇文章      查看所有文章
加:2022-05-08 08:25:31  更:2022-05-08 08:25:46 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/17 22:32:19-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码