gpt4 book ai didi

wagtail - 如何在呈现时将 js/css 附加到 StreamField block ?

转载 作者:行者123 更新时间:2023-12-05 03:07:45 36 4
gpt4 key购买 nike

我知道您可以使用 django 表单媒体 API 和 js_initializer() 方法在 form 中包含 javascript,我已经成功地做到了。但是当我编写的这个自定义 block 的实例显示时,我需要在页面中包含一个 javascript 和 CSS 文件。

是否有特定的机制?还是我只需要在页面模板中包含 js/css 文件?我真的很想避免将它们包含在每个具有 可能 具有此 block 的 StreamField 的页面上,因为绝大多数不会,这意味着浪费了大量的页面加载时间。

最佳答案

这之前曾在 https://github.com/wagtail/wagtail/issues/2490 上讨论过- 我没有尝试过,但我相信您可以通过在返回 django.forms.Media 的相关 block 类上定义 frontend_media 属性来实现此目的对象,以及将这些媒体定义收集到单个对象中的函数(页面模型上的方法可能是一个很好的选择......):

from django.forms import Media

class MyPage(Page):
body = StreamField(...)

def body_media(self):
media = Media()
for block_val in self.body:
if hasattr(block_val.block, 'frontend_media'):
media += block_val.block.frontend_media
return media

关于wagtail - 如何在呈现时将 js/css 附加到 StreamField block ?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46571627/

36 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com