0.2版本号加入的功能

  • 以tag分类图片
  • 美化。添加瀑布流效果
  • 添加tag页和单张图片页
  • 添加公布图片页

以下是具体解释。

每添加一个功能,都要从模型。模板,视图,路由四个方面一一改动。

模型:添加tag属性

思考了一下依照昨天想的分类方法还是没办法考虑全然。于是决定用tag标签分类法。

首先在models.py中新建一个Tag类,仅仅有一个name属性

class Tag(models.Model):
name=models.CharField(max_length=20,null=False,unique=True,default="")
def __unicode__(self):
return self.name
admin.site.register(Tag)

然后在Photo类中指定多对多属性tags

tags=models.ManyToManyField(Tag,related_name='has_photos',blank=True)

模板:添加tag页,photo页和post页

分别用来展示一个tag包括的全部图片和单个图片。

所以tag的展示应该和首页是几乎相同的、

tag.html

    {% extends "base.html" %}
{% block title %}{{tag.name}}{% endblock %}
{% block content %}
<div class="jumbotron">
<h1 align="center">{{tag.name}}</h1>
</div>
<div class="grid-sizer"></div>
{% for photo in tag.has_photos.all %}
<div class="grid-item">
<a href="p/{{photo.id}}/">
<img src="{{photo.url}}">
</a>
<p>{{photo.title}}</p>
<p>{% for tag in photo.tags.all %} <a href='/t/{{tag.id}}/'>{{tag.name}}</a> {% endfor %}</p>
</div>
{% endfor %}
{% endblock %}

在这里在上面设置了一个巨幕来展示tag的名称,以下放上图片。

tag变量由视图传入,然后通过tag.has_photos.all获取该tag全部的图片。

photo.html

    {% extends "base.html" %}
{% block title %}{{photo.title}}{% endblock %}
{% block content %}
<div class="jumbotron" align="center">
<h3>{{photo.title}}</h3>
<img src="{{photo.url}}" >
</div>
<div class="grid-sizer"></div>
{% endblock %}

传入photo然后展示,非常easy。

post.html

post页面须要一个表单来公布图片信息

    {% extends "base.html" %}
{% block title %}公布新图片{% endblock %}
{% block content %}
<form class="form-horizontal panel container" method="POST" action=".">{% csrf_token %}
<div class="form-group">
<label class="control-label" for="exampleReply">标题(必填。每张图片都必须有名字哦):</label>
<input type='text' name='title' value="" class="form-control" id="exampleReply" placeholder=""></input>
</div>
<div class="form-group">
<label class="control-label" for="exampleReply">链接(不支持直接上传,能够先把图片公布到堆糖等站点再把链接粘贴过来。谢谢合作):</label>
<input type='text' name='url' value="" class="form-control" id="exampleReply" placeholder=""></input>
</div>
<div class="form-group">
<label class="control-label" for="exampleReply">标签(多个可用空格隔开):</label>
<input type='text' name='tags' value="" class="form-control" id="exampleReply" placeholder=""></input>
<label class="control-label" for="exampleReply">最好使用含义明白的名词或形容词。能够指明图片来源和图片类型最好。 已有的便签见下</label>
</div>
<div class="form-group col-md-2">
<input type="hidden" name="next" value="/"/>
<input type="submit" class="btn btn-lg btn-primary" value="公布"/>
</div>
</form>
<ul class="list-group">
{% for tag in tags %}
<li class="list-group-item"><span class="badge">{{tag.}}</span>{{tag.name}}</li>
{% endfor %}
</ul>
{% endblock %}

post传递三个參数。图片title,图片链接url,还有tag,tag以字符串形式传递。在视图文件里进行分割并和图片绑定。

路由:添加tag,photo和post的链接

加了三行而已:

    url(r'^post/$',post,name='post_page'),
url(r'^t/(?P<id>\d+)/$',show_by_tag,name='tag_page'),
url(r'^p/(?P<id>\d+)/$',show_photo,name='show_photo_page'),

以id而不是名字的方式在链接中传递信息,事实上是偷个懒,直接依据id获取对象要方便非常多。

视图:添加三个视图

post视图

略微有点复杂,用于展示表单,也用于接收处理数据

    def post(request):
if request.method=='POST':
title=request.POST.get('title')
url=request.POST.get('url')
tags=request.POST.get('tags').split()
new_photo=Photo.objects.create(
title=title,
url=url
)
if tags:
for tag in tags:
new_tag,dummy=Tag.objects.get_or_create(name=tag)
new_photo.tags.add(new_tag)#add tag to new_photo
new_photo.save()
return HttpResponseRedirect('/')
else:
tags=Tag.objects.all()
return render_to_response('post.html',RequestContext(request,{'tags':tags}))

当传输方法是POST时,获取post过来的数据,据此创建一个photo对象,然后把标签字符串分割一个分成单个的标签,加到photo的tags属性里面去,然后保存,跳转到首页。

当传输方法是GET时。直接展示表单页面,只是这里我在表单后面展示了全部存在的tag。

tag和photo视图

    def show_by_tag(request,id):
tag=Tag.objects.get(pk=id)
return render_to_response('tag.html',RequestContext(request,{'tag':tag})) def show_photo(request,id):
photo=Photo.objects.get(pk=id)
return render_to_response('photo.html',RequestContext(request,{'photo':photo}))

获取链接中id相应的tag和photo。然后传递參数就能够了

依旧是用pythonanywhere公布的:

大圣画廊

大圣画廊v0.2(2015.7.17)的更多相关文章

  1. 关于asp.net执行exe程序时权限不够的解决办法(2015.04.17更新)

    一,本文背景 长话短说:asp.net项目中需要用到PDF转换成SWF文件,用户上传后自动调用pdf2swf.exe转换. 但有个问题,执行时权限不够,导致一直报错(滚动条一直在往下滚,刷屏中),见下 ...

  2. 2015.7.17( NOI2015 day1 )

    今天早起做了NOI2015网络同步赛.... 最近NOI是越来越向NOIP靠拢了....但是我还是不会做..... 第一题:程序自动分析 先离散化一下..然后最多就剩20w个数 , 不等于就存起来.. ...

  3. Daily Scrumming* 2015.12.17(Day 9)

    一.团队scrum meeting照片 二.成员工作总结 姓名 任务ID 迁入记录 江昊 任务1077 https://github.com/buaaclubs-team/temp-front/com ...

  4. ButterKnife 8.2.1 大圣归来

    零.前言 ButterKnife是一个视图注入的框架,主要帮我们解决无脑的findViewById.设置监听事件等等体力劳动. 一.引入 好消息是ButterKnife终于使用apt生成代码了,首先在 ...

  5. SQL Server锁定【2015.12.17】

    锁定的体系分类   1.表级锁 保证数据在逻辑上的一致性. 包含:行级锁.分页锁.表.数据分页.LOB分页以及索引叶子级锁. 2.闩 保证数据在物理上的一致性,系统采用,比锁少耗资源,对用户不可见. ...

  6. iOS 学习笔记 五 (2015.03.17)使用storyBoard进行tableview的跳转

    方法一: 点击tableviewCell后,按住ctrl键拖拽至想要跳转的新的界面.这样跳转的结果是,点击tableview中的任何一行都会跳转到新的界面.可以通过控制cell的 属性 userInt ...

  7. ViewPage 大圣归来 原生示例

    VP简介 android-support-v4.jar 是谷歌官方给我们提供的一个兼容低版本安卓设备的软件包,里面包囊了只有在安卓3.0以上可以使用的api.而ViewPage就是其中之一,利用它,我 ...

  8. 【.NetRemoting-2】2015.09.17

    [Remoting架构] [1]是.NetFramework的一个重要组成 [2]框架的两个重要特性 [A]基本实现[B]可扩展/可定制 [各个组成部分] [1][客户端,客户端应用程序域] [组成] ...

  9. 2015/9/17 Python基础(13):函数

    函数是对程序逻辑进行结构化或过程化的一种编程方法. Python的函数返回值当什么也不返回时,返回了None和大多数语言一样,Python返回一个值或对象.只是在返回容器对象时,看起来像返回多个对象. ...

随机推荐

  1. (一)maven之——maven基础及本地仓库的配置

    一.初步了解maven Apache Maven是一个软件项目管理的综合工具.基于项目对象模型(POM)的概念,提供了帮助管理构建.文档.报告.依赖.发布等方法,Maven简化和标准化项目建设过程.处 ...

  2. QQ窗体的控制,同步异步打开360网盘,控制360网盘窗体的移动

     1.通过system启动飞秋进程的方式: 2.Windows下杀死进程的方式是:taskkill /f/im QQ.exe.截图例如以下: watermark/2/text/aHR0cDovL2 ...

  3. for循环和增强版的for循环

    增强的for循环. 缺点:   对于数组.不能方便的訪问下标值.   对于集合,与使用Interator相比.不能方便的删除集合中的内容(在内部也是调用Interator). 除了简单遍历并读取当中的 ...

  4. tcp_handle_req: Made 4 read attempts but message is not complete yet - closing connection

    一.现象 测试opensips时遇到这么一个错误提示: ERROR:core:tcp_handle_req: Made read attempts but message is not complet ...

  5. 使用Open Live Writer写博客

    1. 下载安装软件 安装包路径http://openlivewriter.org/ 2.配置 打开软件后会提示你配置博客账号地址 3.安装代码高亮插件 下载插件源代码https://pan.baidu ...

  6. 使用 SSHFS 挂载远程的 Linux 文件系统及目录

    1. 安装 sudo apt-get install sshfs 2. 创建 SSHFS 挂载目录 sudo mkdir /mnt/cong 3.使用 SSHFS 挂载远程的文件系统 sudo ssh ...

  7. blender, merge顶点

    选择Edit Mode:,和vertex select: 同时选中两个要merge的顶点(同时选中多个顶点:http://www.cnblogs.com/wantnon/p/4526573.html) ...

  8. p4n 今天与朋友沟通支付云服务普及以及跨境电子商务的光辉前景

    p4n 今天与朋友沟通支付云服务普及以及跨境电子商务的光辉前景 跨境电子商务也是个光忙四色和的跨境电子商务啊..支付项目也是个强大的项目.. 过几天我们就要宣布正式发布atipay ,并宣称将致力于推 ...

  9. 06、Windows 10 技术预览

    随着 Windows 10 发布的,未来 Windows 平台都是统一开发模型,可以只写一个 Appx 包,就可以同时部署到 Windows/ Windowsw Phone/ Tablet /xbox ...

  10. 解决将Ubuntu下导出的requirements.txt到Centos服务器上面出现pkg-resource的版本为0.0.0

    最直接有效的方法: 原因: