V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
dangyuluo
V2EX  ›  程序员

关于 Web 搜索分页,应当如何合理组织 uri 中的页面参数呢?

  •  
  •   dangyuluo · 2017-09-12 10:02:17 +08:00 · 1959 次点击
    这是一个创建于 2624 天前的主题,其中的信息可能已经有所发展或是发生改变。

    目前网站需要做几个搜索功能,因此牵扯到了分页。在网站开发的过程中,尽量使用了 Restful 设计思想,如想获取某个用户的所有商品的时候,uri 为:

    /user/41/products
    

    当然这只能获取第一页产品,目前设定是每页 20 个。那么如果我想获取第二页的时候,有两种方案:(我知道这里不符合 Restful 了,不过向后兼容没有办法)

    /user/41/products?from=20
    
    /user/41/products?page=2
    

    第一种方式是是将搜索起始点直接写到参数里,第二种是将需要获取的页面写到参数里。 希望大家指点一下,这两种方案有什么优缺点。

    9 条回复    2017-09-12 13:59:54 +08:00
    viko16
        1
    viko16  
       2017-09-12 10:10:12 +08:00
    看数据量,像微博那种分分钟产生几百条数据的只能用 from=cursor (微博只是随便举的,他家的时间线从来没正常过..
    invoke
        2
    invoke  
       2017-09-12 10:16:20 +08:00
    楼上+1
    如果不用 from 做值的话,可能会导致数据重复的问题,不过用 from 会让查询变的稍微复杂一点。如果数据量不大直接用 page 比较简单方便。
    LeeSeoung
        3
    LeeSeoung  
       2017-09-12 11:04:47 +08:00
    page+size
    lgpqdwjh
        4
    lgpqdwjh  
       2017-09-12 13:45:42 +08:00
    page & pagesize
    littleylv
        5
    littleylv  
       2017-09-12 13:50:06 +08:00
    page=1&pageSize=20
    jziwenchen
        6
    jziwenchen  
       2017-09-12 13:54:26 +08:00
    有啥差别?
    vjnjc
        7
    vjnjc  
       2017-09-12 13:57:04 +08:00
    @viko16 借楼问一下,这种在不同时间 response 会变的接口,能够基于时间来做判断么?
    比如 from={timestamp}这样的?
    还是一定要用 from={unique-key}这样的格式?
    learnshare
        8
    learnshare  
       2017-09-12 13:58:33 +08:00
    ?page=2&size=10
    每页 10 个,取第二页(第 10~19 项)
    mcfog
        9
    mcfog  
       2017-09-12 13:59:54 +08:00
    from=20 相当于 offet=20 吧,我个人的话任何时候都不会做单独这个参数的分页

    page (如果需要自定义,加上 pageSize )的优点在于可读性,尤其是如果再放到 url 里,/products/page/1/或直接 /products/1/,非常清晰

    offset+limit (也就是直接在参数里指定取多少,跳过多少)的优点在于便利做加载更多、懒加载、客户端下拉等逻辑(客户端控制维度更细,前提是同步提供 limit )

    至于 cursor,里面的值应该是上一页的最后一个项目的主键 ID,而不是跳过多少条,好处是数据量大的时候能通过索引规避大 offset 带来的性能问题,问题是跳第 N 页会比较难做(实际上数据量一大跳第 N 页一定不好做)
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   3447 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 28ms · UTC 11:29 · PVG 19:29 · LAX 03:29 · JFK 06:29
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.