3

我有一个以下 django 代码,我在其中返回条目查询集:

def search(request):
    entries_list = Entry.objects.all()
    if request.method == 'GET':
        key = request.GET.get('key', False)
        entries_list = entries_list.filter(key__icontains=key)

    return render(request, 'search.html', {
         'entries': entries_list
    })

我想做的是在我的模板中打印条目(键值对)并将它们存储在本地存储中。我怎样才能做到这一点?我试图返回 JSON 或序列化它,但我没有成功。

即,在我的 javascript(for 循环)代码中,我想插入我的查询集结果,而不是一些数字:

{% extends  'base.html' %}

{% block head %}

<script>
var prefix = "localStorage-";
function myFunction() {
    alert("Page is loaded");
    for(var i = 0; i < 10; i++) {
        var key = i// $("#key").attr('value');
        var value = 2*i//$("#value").attr('value');
        localStorage.setItem(prefix + key, value);      //******* setItem()
        //localStorage[prefix+key] = value; also works
    }
}

</script>


 {% endblock %}

{% block body %} onload="myFunction()"  {% endblock %}

{% block content %}

{% for e in entries %}
    <h3>
        <a href="{% url 'article' e.id %}">{{ e.key }}</a>
    </h3>
    {{ e.value|safe }}
    <hr>
{% endfor %}

{% endblock %}
4

1 回答 1

2

如果我正确理解了这个问题,您想在 Django 模板中生成 javascript 吗?

...
function myFunction()
{
    {% for value in entries %}
        localStorage.setItem(localStorage-{{ forloop.counter0 }}, {{ value }});
    {% endfor %}
}
....

这将产生类似

....
function myFunction()
{
    localStorage.setItem(localStorage-0, 'string_version_of_entry_0');
    localStorage.setItem(localStorage-1, 'string_version_of_entry_1');
    localStorage.setItem(localStorage-2, 'string_version_of_entry_2');
    ...
}
....

请注意,每个Entry都将转换为字符串。显然,您不能只将 Django 对象传输到 javascript。可以通过添加一个def __unicode__(self)to来控制它的转换方式Entry

于 2013-06-08T23:23:32.647 回答