V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
V2EX 提问指南
pxllong
V2EX  ›  问与答

接口对各个客户端数据返回格式

  •  
  •   pxllong · 2016-07-27 20:38:17 +08:00 · 1972 次点击
    这是一个创建于 3068 天前的主题,其中的信息可能已经有所发展或是发生改变。

    说下问题: 现在同一个接口安卓端和 iOS 端渲染的方式不一样。因为涉及到部分 html 标签 例如 "您好,吃饭了么"吃饭需要标红加括号 我现在有几个方案 不知道各位是怎么处理的 1.返回格式自定义标签类似 bbscode Resp: { "content": "您好,color:red吃饭</color>了么",
    } 服务端解析根据标签解析

    2. 直接在服务端根据每个端处理好数据
    安卓:
    Resp: {
    	"content": "您好,<span color="red">(吃饭了么)</span>"
    }
    	
    iOS:
    Resp: {
    	"content": "您好,<span color="#ffffff">[吃饭了么]</span>"
    }
    
    方式一升级了标签就很麻烦,需要对各个版本进行兼容,还是得走到方式二
    方法二 服务端处理麻烦点 需要每个端都要做数据处理,但是数据好控制。
    
    现在犹豫着是让服务端做更多事情还是让客户端做。
    
    
    不知道各位有什么好的经验吗?
    
    谢谢
    
    12 条回复    2016-07-28 09:32:30 +08:00
    dangyuluo
        1
    dangyuluo  
       2016-07-27 20:56:51 +08:00
    我觉得还是让客户端去做比较好。传输的数据应该是不包括样式的。
    pxllong
        2
    pxllong  
    OP
       2016-07-27 21:59:08 +08:00
    补充下:现在数据来源事来自网页端的 html ,涉及到富文本
    ZGLHHH
        3
    ZGLHHH  
       2016-07-27 22:13:57 +08:00
    用"\"防止转义?
    例子:
    <span color="#ffffff">\(吃饭了么\)</span>
    pxllong
        4
    pxllong  
    OP
       2016-07-27 23:06:35 +08:00
    @ZGLHHH 不是, 是安卓和 ios 处理富文本需要的数据格式问题 。由服务端算还是客户端算 约定一套 bbscode
    ZGLHHH
        5
    ZGLHHH  
       2016-07-27 23:11:50 +08:00
    @pxllong 我觉得应该选客户端
    xenme
        6
    xenme  
       2016-07-27 23:14:26 +08:00 via iPhone
    服务端只返回数据比较好,各平台自己处理显示和平台差异部分
    pxllong
        7
    pxllong  
    OP
       2016-07-28 00:01:48 +08:00
    客户端做 服务器只能返回

    您好,[i][size=4][font=黑体][u][b]吃饭了么?[/b][/u][/font][/size][/i]
    3dwelcome
        8
    3dwelcome  
       2016-07-28 01:28:48 +08:00 via Android
    我以前也觉得数据和样式分离比较优雅、但实际操作下来、除了让前端代码更多更复杂外、并没有带来特别的好处。

    现在选的话、我会选第二种。
    angelface
        9
    angelface  
       2016-07-28 07:46:17 +08:00
    服务端返回基本结构,客户端加样式。
    pxllong
        10
    pxllong  
    OP
       2016-07-28 09:09:25 +08:00
    @angelface

    现在数据解析需要些多套
    ios 一套 安卓一套 js 一套 后端一套
    感觉成本略高
    sunhr
        11
    sunhr  
       2016-07-28 09:21:21 +08:00   ❤️ 1
    我是做客户端的,选第二种,理由如下:

    1 、节省时间——照 LZ 描述, App 这边应该是用了直接可以渲染 HTML 标签的富文本控件,那么如果 Server 返回处理好的数据, App 直接扔进去就可以了。否则的话 iOS 开发搞一遍, Android 开发再搞一遍,浪费资源,容易出错。

    2 、灵活可控——假设 App 已经上线,突然发现标签有 bug 或者突然有运营需求过来需要修改文字或样式,第二种方案可以分分钟搞定

    现实开发中,经常会遇到类似的问题, Server 和 App 都认为应该对方去实现。拉大家一起权衡一下利弊, 80%的情况最后都交给 Server 了,毕竟移动设备的电量和流量有限= =
    pxllong
        12
    pxllong  
    OP
       2016-07-28 09:32:30 +08:00
    @sunhr
    感谢回复。
    我现在倾向也这个 服务端好控
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   1358 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 25ms · UTC 17:26 · PVG 01:26 · LAX 09:26 · JFK 12:26
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.