fzngagan
(Faizaan Gagan)
1
有时,站点管理员需要确保所有用户在侧边栏中看到相同的类别集。以下是操作方法:
- 从
default navigation menu categories 中移除所有类别并保存。当被提示时,请确保将更改历史性地应用。
- 等待几分钟。
- 将所有希望所有用户显示的类别添加到
default navigation menu categories。同样,当被提示时,请确保将更改历史性地应用。
“历史性地应用”意味着将此更改应用于现有用户,同时为未来加入的用户设置默认值。当您看到以下模态框时,需要点击 Yes:
注意:此设置不会使没有访问权限的用户看到私有类别。
5 个赞
Moin
2
一次性移除之前的默认设置并添加新设置,与分两步进行(中间间隔一段时间)有什么区别?
我曾短暂认为这个过程会重置所有个性化自定义。但根据我的测试,事实并非如此。如果某个类别之前不在侧边栏的默认设置中,而是由用户自行添加的,那么即使清除了设置,它也不会被移除。只有之前在设置中配置的类别会被移除。
因此,若要使所有人的侧边栏保持一致,你需要执行以下步骤:
- 将所有类别添加到设置中(并且最好不要为所有人覆盖此设置)
- 然后从设置中移除所有类别,并为所有人覆盖此设置
- (等待几分钟?)
- 添加新的类别,并为所有人覆盖此设置
此处需要将步骤 2 和步骤 4 分开,因为步骤 1 并未应用到所有人身上。我们可以将步骤 1 应用到所有人,使所有人的侧边栏都包含所有类别,几分钟后,再移除我们不希望出现在他们侧边栏中的类别。但这可能会导致几分钟内用户体验变差。
我的测试(显示清除手动添加类别的设置不会被移除)是否不正确?步骤分离是否有其他原因?我想了解这一点,以便决定是否需要将相关信息添加到 Configuring the default sidebar for your users
3 个赞
fzngagan
(Faizaan Gagan)
5
@Moin
这里的回填(backfilling)工作方式与通常的预期略有不同。当更新“默认导航菜单类别”设置时,我们并不会简单地重置所有用户的侧边栏类别。我们的做法如下:
- 如果管理员在设置中添加了一些类别,那么只有这些新添加的类别会被加入到尚未设置这些类别的所有用户的侧边栏中。
- 如果从设置中移除了某些类别,那么这些类别也会从所有用户的侧边栏中移除。
因此,回填并不会强制将设置的状态应用到所有用户,而是仅对设置中新增或移除的类别进行增量更新。
这样做的主要原因是为了保留每个用户的个人偏好。
引入此行为的 PR 如下:
我们曾尝试通过以下两种方式使所有用户拥有相同的类别:
- 全部添加,按历史应用;再移除部分,按历史应用。
- 全部移除,按历史应用;再添加部分,按历史应用。
在最近一次针对大型站点的尝试中,方法 1 未能正常工作,而方法 2 则成功了。因此我记录了方法 2。
如果您有时间,请尝试用一批用户测试这两种方式,看看是否有效。如果需要,我可以编写一个 SQL 查询来确认更新是否按预期生效。请随时告诉我您的想法。
1 个赞
Moin
6
我再次尝试了您在第一篇文章中描述的步骤。但我仍然注意到同样的问题:用户添加到其侧边栏的类别并未被移除,因此结果并非所有用户在其侧边栏中都拥有相同的类别。
详细复现步骤
- 我创建了一个全新的论坛
- 我创建了 5 个类别(category1、category2、category3、category4、category5)
- 我使用“编辑侧边栏类别”选项将
category4 添加到了我的侧边栏
- 该类别已添加到我的侧边栏
- 我查看了
default_navigation_menu_categories 站点设置
- 正如您在指南中所说,我移除了所有类别
并将更改应用给所有用户
7. 现在该设置已为空
8. 我检查了我的侧边栏,只有手动添加的 category4 在其中(底部的站点设置链接也表明该站点设置已为空)
9. 我等待了约 45 分钟,然后将 category1、category2 和 category3 添加到了设置中
并将更改应用给所有用户
基于本指南标题的预期结果:所有用户在其侧边栏中都拥有相同的类别,即仅包含设置中的类别,不包含其他内容。
实际结果:category4 仍然在侧边栏中,而对于未手动添加该类别的用户,其侧边栏中并没有它。
您期望在哪个步骤中移除用户手动添加到其侧边栏的类别(在我的例子中是 category4),从而实现所有用户侧边栏中拥有相同类别的结果?
根据您在这里所说的,我预期它不会被移除,因为该类别并未从设置中移除,因为它本来就不在设置中。但您说您使用这些步骤来强制所有用户拥有相同的类别。
如果我添加了所有类别(方法 1),category4 将会被添加然后被移除,所以我预期它会消失。这就是我理解发生的情况的地方。但您的指南说我应该使用方法 2,所以我想知道我在理解或测试中遗漏了什么。
1 个赞