有关前后端交互的协议请教

6 天前
 fingerxie

我们公司是前端不想做字段 key 到 value 的映射,要求每次返回给前端时都返回具体的枚举信息。有时候我们就得跨服务去查询枚举用户信息、字典信息。 甚至是原本可能是一个相对复杂的对象,前端都要求把对象重组,最好平铺着放到外层实体中。

{
'object':{
	'key':'value'
}

}

我觉得这样不太合理,但是前端不愿意做,领导对此也不支持。V 友们你们觉得呢?我又该如何说服他们和领导呢?

1442 次点击
所在节点    程序员
15 条回复
ychost
6 天前
所以需要一个 BFF 层,这玩意前后端做都不合适
fingerxie
6 天前
@ychost 我感觉 BFF 层一方面是人力成本的上升,公司不会支持。另一方面这 BFF 层不应该是前端映射久了,厌倦了,由此衍生出的吗?
woodytang
6 天前
没听明白,他要你在 DTO 层做很多连表 ,对象转换变形吗? 还是说你枚举信息的返回格式??

枚举信息你给他一个统一接口,让他到你的字典里面查不就可以了
hetal
6 天前
我们用的是 protobuf 来统一前后端( Web/App 等),一键生成自己想要的代码
rabbbit
6 天前
没看懂,举个实际的例子?
rabbbit
6 天前
是这个意思嘛?
你的
{
'user': {name: '', age: '', sex: '1'},

}
rabbbit
6 天前
前端要求的
{
'user': {name: '', age: '', sex: '男'},
}

然后有个字典表
{1: '男',2: '女'}

是这样吗?
wuzzispacelake
6 天前
个人实践是服务器处理,因为对多端的时候不可能让每一端自己都这样拼接一遍,所以接口对外会有一套 model ;然后问题是如何快速生成和分发这个 model 至客户端,比如以代码生成的方式生成给各个端,而不是让客户端手打一遍
flmn
6 天前
我一般这样给前端返回的:

{
'user': {name: '', age: '', sex: '1', sexName: '男'},
}

自取所需。
fingerxie
5 天前
@woodytang 他不去组装,所以给他字典表也没用
zhangyaowen1995
5 天前
我们公司也是,需要字典翻译的都是统一后端翻译好,不会交给前端,一般在需要翻译的字段名称加上 label 。比如 {sex:"1",sexlabel:"男"},很久之前也是让前端自己用字典表翻译,但是会有个问题,如果一个页面需要翻译的字段特别多,并且字典表又很大的情况下(比如客户,城市,地址),页面会很卡顿,用户体验非常差,所以后面都统一都是后端翻译好。
guanzhangzhang
5 天前
换 protobuf
lyxxxh2
5 天前
看得我一脸懵逼,读了一遍又一遍才理解意思。

第一遍: 后端问题返回问题,还得继续看
第二遍: 前端不想做,领导对你也不支持。
第三遍: 前端不想做,领导也不支持前端。
第四遍: "我又该如何说服他们和领导呢?" 领导原来支持前端了。
...

你所举的对象,返回很正常。
看了 6 楼才知道啥问题。

前端不会问我这些问题,我常量复制到接口文档,自己看。
reallycool
5 天前
给他们说,能干就干,不干滚蛋
oldManNewThought
5 天前
我们这样做。后端返回的字典,该什么就是什么。前端有个专门的字典组件。属性设置成字典的类型。内部就请求后端获取对应的翻译。同时在前端会做缓存,不用每次请求

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/1072741

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX