在Django中在urlpatterns之间共享变量

0 投票
1 回答
581 浏览
提问于 2025-04-18 07:58

这是我的 urls.py 文件

from django.conf.urls import patterns, url, include
from geartables import views
from geartables.views import DataTable


urlpatterns = patterns('',
                       url(r'^$', views.index, name='index'),
                       url(r'^data/$', DataTable.as_view(), name='DataTable'),
                       url(r'^(?P<product_type>[\w\-]+)/$', views.table, name='table'),
)

当用户访问 "localhost/table/" 时,会根据一个模板生成一个页面。在这个模板里,有一个 {% url %} 标签,它会调用 DataTable 类(用来创建 JSON 数据)。

所以我想问的是,如何在 views.py 文件中让 DataTable 类调用我的变量呢?

像这样:

class DataTable(BaseDatatableView):
    model = <product_type>
    ...

补充:

views.py 文件:

...
def table(request, product_type):
    ptype = ProductType.objects.get(url_name=product_type)
    datatable = 'DataTable'
    context = {'mselectmenus': ptype.mselects, 'columns': ptype.columnlist, 'datatable':'DataTable}
    return render(request, 'geartables/dtcode.html', context)

class DataTable(BaseDatatableView):

    p = ProductType.objects.get(name=<product_type>)
    model = p.modelname
    columnlist = p.columnlist  # ex: [["th_pic","Picture"],["brand_name", "Brand"]]
    mselects = p.mselects
    ranges = p.ranges
    max_display_length = 2000

    def __init__(self):
        self.columns = [item[0] for item in self.columnlist]
        self.order_columns = self.columns

    #multiple select filters

    def mselectmenus(p):
        mselectmenu = []
        for item in p.mselects:
            mselectmenu.append(
                [item[1], item[0], p.model.objects.values_list(item[0], flat=True).order_by(item[0]).distinct()])
        return mselectmenu


    #initial render
    def render_column(self, row, column):
        if column == 'th_pic':
            return '<a href=' + row.lg_pic + '><img src=' + row.th_pic + ' /></a>'
        elif column == 'description':
            return ''
        else:
            return super(DataTable, self).render_column(row, column)

    #filtering
    def filter_queryset(self, qs):
        #search bar
        ssearch = self.request.GET.get('sSearch', None)
        if ssearch:
            qs = qs.filter(Q(brand_name__icontains=ssearch) | Q(product_name__icontains=ssearch) | Q(
                rope_type__icontains=ssearch) | Q(length__icontains=ssearch) | Q(diameter__icontains=ssearch) | Q(
                weight__icontains=ssearch) | Q(falls__icontains=ssearch) | Q(color__icontains=ssearch))

        #mselect
        ssearch_1 = self.request.GET.get('sSearch_1', None)
        if ssearch_1:
            qs = qs.filter(Q(brand_name__regex=ssearch_1))

        return qs
...

模板代码:

...
$(document).ready(function() {
    var dtable = $('#{{ ptable }}').dataTable( {
        //"oLanguage": oLanguages,
        "sDom": 'C<"clear">lfrtip',
        "aoColumns": [
            { "bSortable": false, "bSearchable:": false, "sClass": "center" },
            { "bSortable": true, "bSearchable:": true,  "sClass": "center" },
            { "bSortable": true, "bSearchable:": true,  "sClass": "center" },
            { "bSortable": true, "bSearchable:": false,  "sClass": "center" },
            { "bSortable": true, "bSearchable:": true,  "sClass": "center" },
            { "bSortable": true, "bSearchable:": true,  "sClass": "center" },
            { "bSortable": true, "bSearchable:": true,  "sClass": "center" },
            { "bSortable": true, "bSearchable:": true,  "sClass": "center" },
            { "bSortable": true, "bSearchable:": true,  "sClass": "center" },
            { "bSortable": true, "bSearchable:": false,  "sClass": "center" },
        ],
        "bProcessing": true,
        "bServerSide": true,
        "sAjaxSource": "{% url datatable %}",
    });
...

1 个回答

1

好的,使用 {% url view_name param1 param2 ... %} 这个语法,你是在把一些参数(比如 param1、param2 等)传递给你的视图(view)。这里的 view_name 是你在 urlpatterns 中为你的视图定义的名字。

所以,你需要使用这个网址:

url(r'^data/<product_type>/$', DataTable.as_view(), name='DataTable'),

然后,为了在你的 DataTable 中获取这个 product_type,你需要在里面实现一个叫 dispatch 的方法:

def dispatch(self, request, *args, **kwargs):
        self.product_type= kwargs.pop("product_type")
        return super(LanguageMixin, self).dispatch(request, *args, **kwargs)

编辑: 另一种方法是保持你的 url 不变,使用 GET 请求。如果你想把它作为一个 GET 参数传递,那么最好的地方是在 get_context_method 里面获取它:

def get_context_data(self, **kwargs):
        expand_text = self.request.GET.get('product_type')

为了把它作为一个 GET 参数获取,你需要正确构造网址,添加 GET 参数。像这样:

<a href="{% url view_name %}?product_type={{ some_product_type }}">

记住,{% url view_name %} 只是构建了一个字符串,并不会进行重定向。

撰写回答