Django 1.6:在另一个模板中显示特定的模型对象 [英] Django 1.6: Displaying a particular models Objects in another template

查看:116
本文介绍了Django 1.6:在另一个模板中显示特定的模型对象的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

在我的应用程序中,我有一对多的关系,我有很多产品,一些特定的产品将只与一个网站相关。

Working on an application were I have a One to Many relationship where I have many Products and a few particular products will be related to only one Website.

在我的首页是从我的网站模型显示我的列出的网站的地方,我想展示产品,当用户点击我的主页上的任何人被重定向到产品页面模板),其中我将所有与产品模型相关的对象与该特定网站相关联。

On my Home page is where I display my listed sites from my Website Model I would like to show products for when the user clicks on anyone of the slugs on my Homepage the are redirected to go into a product page ( another template ) where I have all of the objects related from my Product Model to that particular website to display only.

这是一个我的情况的用户流程

主页 - >点击网站('/ browse / website_slug')--->转到 - >产品页面(仅填写相关点击的产品对象)

Homepage --> click on website ('/browse/website_slug') ---> Go To --> Product page (filled with only Product Objects from related clicked slug)

产品型号

class Product(models.Model):
    """
    The product structure for the application, the products we scrap from sites will model this and save directly into the tables.
    """

    product_name = models.CharField(max_length=254, verbose_name=_('Name'), null=True, blank=True)
    product_price = CurrencyField( verbose_name=_('Unit price') )
    product_slug_url = models.URLField(max_length=200,  null=True, blank=True)
    product_category = models.CharField(max_length=254, blank=True, null=True)
    product_img = models.ImageField('Product Image', upload_to='product_images', null=True, blank=True) 
    product_website_url = models.URLField(max_length=200,  null=True, blank=True) 
    product_website_name = models.CharField(max_length=254, blank=True, null=True)

    #For Admin Purposes, to keep track of new and old items in the database by administrative users
    date_added = models.DateTimeField(auto_now_add=True, null=True, blank=True, verbose_name=_('Date added'))
    last_modified = models.DateTimeField(auto_now=True, null=True, blank=True, verbose_name=_('Last modified') )

    #For Admin Purposes, to make sure an item is active by administrative users
    active = models.BooleanField(default=True, verbose_name=_('Active') )

    # Foreign Key
    website = models.ForeignKey(Website, null=True, related_name='website_to_product')

网站模型

class Website(models.Model):
    name = models.CharField(max_length=254, blank=True, null=True, unique=True)
    description = models.TextField(null=True, blank=True)
    website_slug = models.SlugField(verbose_name=_('Website Slug'), unique=True)
    site_logo = models.ImageField('Websites Logo', upload_to='website_logo_images', null=True, blank=True) 

    menswear = models.BooleanField(default=False, verbose_name=_('Menswear'))
    womenswear = models.BooleanField(default=False, verbose_name=_('Womenswear'))


    active = models.BooleanField(default=True, verbose_name=_('Active'))



我的product_extend应用程序



view.py

 class ProductView(ListView):

    context_object_name = 'product_list'
    template_name = 'product_extend/_productlist.html'
    # queryset = ProductExtend.objects.filter(id=1)
    model = Product

    def get_context_data(self, **kwargs):
        context = super(ProductView, self).get_context_data(**kwargs)
        return context

class WebsiteView(ListView):

context_object_name = 'home'
template_name = 'homepage.html'
queryset = Website.objects.order_by('name')
model = Website

def get_context_data(self, **kwargs):
    context = super(WebsiteView, self).get_context_data(**kwargs)
    return context



模板



Homepage.html

  {% for object in home %}
        <li class="page_tiles-home home-website-reveal"> 
            <a href="browse/website_slug" data-title="{{object.name}}" data-description="{{object.description}}">
                <img alt="{{object.name}}" src="{{MEDIA_URL}}{{object.site_logo}}" />
            </a> 
        </li>  
    {% endfor %}

Product.html p>

Product.html

{% for object in product_list %}
    <li class="col n-4">
        <figure class="rollover site">
            <div class="scrap-likes"><span class="icon-heart"></span></div>
            <img src="{{object.product_img}}" width="470" height="700">
           <!--  <div class="scrap-from"> Scrapped from:<a class="scrap-site" target="_blank" href="{{object.product_website_url}}">{{object.product_website_name}}</a></div> -->
            <div class="scrap-designer"> Scrapped from: <a class="scrap-site" target="_blank" href="{{object.product_website_url}}">{{object.product_website_name}}</a></div>
            <div class="scrap-title">{{object.product_name }}, <span class="scrap-price">${{object.product_price}}</span></div>
            <a class="scrap-buy" target="_blank" href="{{object.product_slug_url}}">View Item</a>
        </figure>
    </li>
    {% endfor %}



Urls



我的应用程序urls.py

  urlpatterns = patterns('',
     url(r"^$", WebsiteView.as_view(), name="home"),
     url(r'^browse/', include('product_extend.urls')),
    )

我的应用程序product_extend urls.py

  urlpatterns = patterns('',
     ??? No clue what to put ???
   )


推荐答案

您可以在 product_extend urls.py 中添加: / p>

You can add this in product_extend urls.py:

urlpatterns = patterns('',
    url(r'^(?P<website_slug>[\w]+)$', ProductView.as_view(), name='products_list'),
)

然后在 ProductView 中覆盖 get_queryset 方法以使用 website_slug 过滤查询集:

Then in ProductView override the get_queryset method to use the website_slug for filtering the queryset:

class ProductView(ListView):

    context_object_name = 'product_list'
    template_name = 'product_extend/_productlist.html'
    # queryset = ProductExtend.objects.filter(id=1)
    model = Product

    def get_context_data(self, **kwargs):
        context = super(ProductView, self).get_context_data(**kwargs)
        return context

    def get_queryset(self):
        qs = super(ProductView, self).get_queryset()
        return qs.filter(website__website_slug__exact=self.kwargs['website_slug'])

这篇关于Django 1.6:在另一个模板中显示特定的模型对象的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆