对论坛帖子该怎么排序?

2016-02-10 09:59:24 +08:00
 honmaple
主要是看到 v2,百度贴吧都有这样一个问题

在首页有 A,B,C 三个帖子,但是由于回答数少而新帖子多很快沉到了第二页,这时我刚好点击第二页,所以我又在第二页看到 A,B,C 三个帖子,同样的道理,在第三,第四页甚至以后几页也看到这三个帖子。
这样对于用户体验,或是其它方面来说都不太好,请教各路大神,这个问题有什么高效的解决方案吗?
2800 次点击
所在节点    问与答
16 条回复
Devin
2016-02-10 10:23:40 +08:00
适当增加首页帖子数?
gamexg
2016-02-10 10:28:58 +08:00
ajax 翻页+预读几页?
icybee
2016-02-10 10:29:44 +08:00
感觉是没什么好办法的
jybox
2016-02-10 10:39:08 +08:00
既然帖子列表是时间顺序,那么用时间代替页数不就好了么。例如访问首页时,列表中最后一个帖子的回复时间是 T1, 那么在点击「下一页」的时候,客户端向服务器发请求获取「回复时间早于 T1 」的帖子即可。
wujichao
2016-02-10 11:11:10 +08:00
lz 上说的瀑布流是一种方法
还有一种是前端去重, 存在已经浏览过的页的所有帖子 id 然后新的一页遍历一下去重
honmaple
2016-02-10 15:31:47 +08:00
@Devin 这样感觉治标不治本
honmaple
2016-02-10 15:33:00 +08:00
@gamexg 预读不应该是浏览器的事吗?
honmaple
2016-02-10 15:39:01 +08:00
@jybox 有的帖子的确是按时间顺序,但是有的是按照一定时间内回复数或浏览数排序的,这样的发帖时间就乱了
honmaple
2016-02-10 15:43:58 +08:00
@wujichao 多谢,这的确是个办法,不过感觉效率不会太高
wujichao
2016-02-10 16:02:43 +08:00
@honmaple 哈哈 1k 个帖子 x 新的 50 个帖子 去重 猜猜要多长时间? 估计就几 ms 吧 没测试过 求喷
大不了搞成 set 效率真的不是只有 1k 个帖子要考虑的
FrankFang128
2016-02-10 16:46:19 +08:00
这样很正常
gamexg
2016-02-10 16:53:56 +08:00
@honmaple 一般情况下只会翻几页,那么可以考虑用户打开页面时一次性加载 5 页的内容,使用 ajax 翻页,超过预读的内容再从服务器拉取。预读时同一时间加载的内容是可以保证无重复的。
wy315700
2016-02-10 16:55:46 +08:00
加一个缓存,一次用户访问把后面的帖子顺序都缓存起来,保证翻页的时候不看到重复的帖子
evlos
2016-02-10 17:07:30 +08:00
一次性加载多页 +1

帖子列表用户一般只看头几页,而且受用户回复影响需要重新排序的帖子也只会在头几页。
matrix67
2016-02-10 17:44:51 +08:00
阮一峰的博客上有六种算法详解
zonghua
2016-02-10 19:05:58 +08:00

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

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

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

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

© 2021 V2EX