测试平台系列(14) 编写类postman页面(3)

编写类postman页面(3)

回顾

记得上一节我们编写了postman的中间部分,其实还有header部分的一些表单数据没有编写完成,今天我们就尽量完成它并且尝试跑一个小小的demo。

寻找可编辑表格组件

image

可以看到这里比较简单,基本上就是2块: 文字部分可编辑表格

可编辑表格的话,我们可以自己写,也可以直接用现成的。我们为了傻瓜一点,就采用ant design pro封装好的高阶组件(意思是功能齐全,简单好用)

具体地址: ProComponents

image

那么这个就是我们需要的,由于我们用的JavaScript而非TypeScript,所以呢我们需要复杂一点找到对应的源码:

先展开代码然后点击这个js图标
image

在弹出的网站就可以找到对应的JS代码了!

我们这个项目本来就带有了pro的组件,所以不需要额外安装了哈。(亲测新版本还有点问题)

编写可编辑表格雏形

首先呢,我们这个组件是postman组件,但是其实这个可编辑组件是可以和后面的headers标签进行复用的,所以我们单独把这个组件抽出来封装。

新建src/components/Table/EditableTable.jsx

image

代码基本上是复制过来的,但是我们抽取了几个重要的参数:

  • columns

    由于我们的每个表格的字段可能不一样,所以说我们不能写死

  • dataSource

    实际数据,本来不是这样的,但是发现这个组件有点bug,让我有点小尴尬

  • setDataSource

    改变dataSource的方法

  • title

    比如这里我们需要的title是Query Params

image

注意这里,这里我是从columns中拿到真实字段,因为咱们还有其他字段比如后面的删除,拿到之后在用户点击新增一行数据的时候默认给字段加上值。

引入表格组件并编写columns

image
  • columns
image

我设置了3个字段分别是KEY,VALUE, DESCRIPTION。与postman是保持一致的,然后最后一列我设置了一个图标(删除),删除方法自己手动编写了(还是因为他有bug,无法删除)。因为我在官网没改源码的情况下也发现无法删除

看看效果:

雏形是有了

其实postman做的更精致,下面的数据会改变url的内容。接下来我们也把这块实现了吧。

改造URL

现在我们有了params参数,那么我们的url就由2部分构成了:

  • url
  • params

所以我们原先的url改变的时候如果有参数变动则需要修改参数项目,如果参数项目有变动也需要修改url

由于这个ProTable有一点点bug,笔者也搞了好久今晚,不过最后顺利完成了,大家pull最新的代码就可以看到效果了。可惜的是今天浪费太多时间了,就只简单对代码稍作描述了。

image

这个表格组件有些变化:

  • 把正在编辑的key和修改可编辑key的方法抽离出来了
  • extra函数用来在表格数据变动的时候做一些额外的变动,因为表格变化我们得去更新url

拼接url的方法

image

url的规则是 http://www.xxx.com + ?参数1=值&参数2=值2

所以第一个参数用?隔开,后面都是用&,代码写的很清楚了。

拆解url的方法

image

这里写的比较复杂,首先判断url里面有无参数,没有的话就把表单数据清空。接着就是取url的数据组成新的表单。但是表单的每一行是用时间区别的,这里js执行太快,所以我以数组索引+时间+10的方式,就算now全都一样,也没关系,因为索引肯定不一样,避免了一下子添加多行的问题(当然你们是看不到这个问题的)。

删除参数

image

删除参数的时候也重新拼接url给url输入框

输入框url变化也改变参数表格

image

新增了一些变量和set变量的方法

image

文件总体代码可以去github看,这里篇幅有限就不贴了。

最终效果

找了个截图软件,让大家看看效果吧,晚安。

image

项目地址

后端代码地址: https://github.com/wuranxu/pity

前端代码地址: https://github.com/wuranxu/pityWeb

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,384评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,845评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,148评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,640评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,731评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,712评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,703评论 3 415
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,473评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,915评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,227评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,384评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,063评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,706评论 3 324
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,302评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,531评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,321评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,248评论 2 352

推荐阅读更多精彩内容