我想在模板中调用函数,例如:
class ChannelStatus(models.Model):
..............................
..............................
def get_related_deltas(self,epk):
mystring = ""
if not self.get_error_code_delta(epk):
return mystring
else:
for i in self.get_listof_outage():
item = i.error_code.all()
for x in item:
if epk == x.id:
mystring= mystring +" "+str(i.delta())
return mystring
当我想从模板中调用它时: 假设在渲染时,我将channel_status_list传递为
channel_status_list = ChannelStatus.objects.all()
{% for i in channel_status_list %}
{{ i.get_related_deltas(3) }}
{% endfor %}
这不起作用,我可以调用一个不消耗任何东西的函数,但是如果它有参数则无法找到该怎么办
干杯
答案 0 :(得分:81)
您无法使用模板中的参数调用函数。您只能在视图中执行此操作。或者你可以写一个custom template filter,看起来像这样:
@register.filter
def related_deltas(obj, epk):
return obj.get_related_deltas(epk)
现在您可以在模板中执行此操作:
{% for i in channel_status_list %}
{{ i|related_deltas:3 }}
{% endfor %}
答案 1 :(得分:34)
如果该方法不需要任何参数,您可以使用@property装饰器并在模板中正常访问它。
class ChannelStatus(models.Model):
...
@property
def function_you_want_as_property(self):
mystring = ""
...
答案 2 :(得分:6)
对于> 1个参数,使用simple tags:
@register.simple_tag
def related_deltas(obj, epk, second_arg):
return obj.get_related_deltas(epk, second_arg)
模板:
{% for i in channel_status_list %}
{% related_deltas i 3 4 %}
{% endfor %}
(请注意语法从{{
更改为{%
)
可以采用位置参数(例如related_deltas i 3 second_arg=4 debug=true
)。
答案 3 :(得分:5)
如果您发现到处运行的属性太多,或者您为其他所有方法都有模板过滤器,那么在IRC上建议使用另一种解决方案,感谢@FunkyBob。它有点好,呃,时髦但在某些情况下很好。
class MethodProxy(object):
"""For consolidating into 1 method the calling of methods with various single args
(suitable dictionary keys)
class MyModel(models.Model):
...
def magic(self, value):
# Free the ponies
def thing(self):
return MethodProxy(self.magic)
# Usage
>>> m = MyModel()
...
>>> m.thing['value'] == m.magic('value')
# template
{{ m.thing.value }}
"""
def __init__(self, method):
self.method = method
def __getitem__(self, key):
return self.method(key)
答案 4 :(得分:2)
另一种选择是定义属性。 请参阅http://adam.gomaa.us/blog/2008/aug/11/the-python-property-builtin/。
你编写的功能几乎可以做你想要的任何事情。 您将其设为只读属性。 您可以从模板中调用该属性。
Etvoilà!!!!