如何通过 Hotwire Turbo 流正确渲染图像?
How do I correctly render images via Hotwire Turbo streams?
我的问题:使用 Hotwire/Turbo 渲染图像时,所有 URL 都使用主机 example.org
而不是我的实际主机名进行渲染。常规视图很好,但通过 Turbo 流渲染局部视图会导致 ActiveStorage URLs,如 http://example.org/.../
.
上下文:我有一个简单的 Todo 应用程序,有一个工作视图、部分视图和 turbo 流,它们一起显示一个 Todo 和一个关联用户列表。当我将用户加入 Todo 时,turbo 流呈现正确的部分,并将用户名和头像放在我想要的 DOM 中。但是,来自 ActiveStorage 的映像 URL 包含 example.org
主机名。
我在 config/environments/*.rb
中设置了我的标准 URL 选项,包括 routes.default_url_options[:host]
和 config.action_mailer.default_url_options[:host]
。我还了解了文件 config/initializers/application_controller_renderer.rb
,您可以在其中设置一个 http_host
参数;然而,我设置了 http_host
,https
布尔值,Turbo 仍然用 example.org.
渲染我的 image_tag
此外,我发现关于如何以编程方式操作默认渲染器(以解决问题)的建议有限。 This source 表示抓取 ApplicationController.renderer
并覆盖属性,如下所示:
renderer = ApplicationController.renderer.new(
http_host: request.host_with_port,
https: (request.protocol == "https://"),
"rack.session": request.session
)
但是 broadcast_action_to
方法似乎不接受 renderer
参数,所以这在 Turbo 中实际上对我没有帮助。
肯定有一个配置是我遗漏的,但我没有在 Turbo 或 Hotwire 文档中找到它。
我失踪了config.action_controller.default_url_options
。一旦我将其配置为与其他 default_url_options 相同,我的链接便开始正确呈现。
我的问题:使用 Hotwire/Turbo 渲染图像时,所有 URL 都使用主机 example.org
而不是我的实际主机名进行渲染。常规视图很好,但通过 Turbo 流渲染局部视图会导致 ActiveStorage URLs,如 http://example.org/.../
.
上下文:我有一个简单的 Todo 应用程序,有一个工作视图、部分视图和 turbo 流,它们一起显示一个 Todo 和一个关联用户列表。当我将用户加入 Todo 时,turbo 流呈现正确的部分,并将用户名和头像放在我想要的 DOM 中。但是,来自 ActiveStorage 的映像 URL 包含 example.org
主机名。
我在 config/environments/*.rb
中设置了我的标准 URL 选项,包括 routes.default_url_options[:host]
和 config.action_mailer.default_url_options[:host]
。我还了解了文件 config/initializers/application_controller_renderer.rb
,您可以在其中设置一个 http_host
参数;然而,我设置了 http_host
,https
布尔值,Turbo 仍然用 example.org.
image_tag
此外,我发现关于如何以编程方式操作默认渲染器(以解决问题)的建议有限。 This source 表示抓取 ApplicationController.renderer
并覆盖属性,如下所示:
renderer = ApplicationController.renderer.new(
http_host: request.host_with_port,
https: (request.protocol == "https://"),
"rack.session": request.session
)
但是 broadcast_action_to
方法似乎不接受 renderer
参数,所以这在 Turbo 中实际上对我没有帮助。
肯定有一个配置是我遗漏的,但我没有在 Turbo 或 Hotwire 文档中找到它。
我失踪了config.action_controller.default_url_options
。一旦我将其配置为与其他 default_url_options 相同,我的链接便开始正确呈现。