我有一个网站,其中包含动态数量的小部件,金字塔视图(views.py)调用页面,并发送数据:
View.py:
@view_config(route_name='home', renderer='templates/home.pt')
def home_view(request):
widgets = #do sql stuff#
return widgets
layout.t:
<html>
<head>
<title>Title</title>
</head>
<body>
<div class="container">
<div tal:omit-tag="" metal:define-slot="content"/>
</div>
<script src="//ajax.googleapis.com/ajax/libs/jquery/1.8.3/jquery.min.js"></script>
<more tal:omit-tag metal:define-slot="js-more"></more>
</body>
</html>
home.pt:
<div metal:fill-slot="js-more">
<script src="pagespecific.js"></script>
</div>
<div metal:use-macro="load: layout.pt">
<div metal:fill-slot="content">
Page Content!!!!
</div>
<div class="widgets-stuff">
<div class="modulecontent" tal:repeat="_widgets widgets">
<div tal:omit-tag="" metal:use-macro="load: widgets/${_widgets.template}.pt" />
</div>
</div>
</div>
widgetSample.pt:
<div class="morewidgetstuff">
A widget!
</div>
我希望能够在小部件模板上添加新的js,如下所示:
widgetSample.pt:
<div metal:add-to-slot="js-more">
<script src="widgetspecific.js"></script>
</div>
<div class="morewidgetstuff">
A widget!
</div>
ps:我知道这没有多大意义,这只是一个例子
答案 0 :(得分:0)
您需要在呈现所有小部件的模板中填充插槽(从而为小部件添加任何所需的JavaScript)(在您的情况下为home.pt
)。
这是唯一合理的,因为如果你有两个需要相同资源的小部件,你只需要包含一次。在您拥有所有小部件集的级别确定唯一集合要容易得多。