Django:快速搭建简单的Blog

操作方法

  • 01

    一,创建项目 1, 为blog创建名为mysite的工程项目: django-admin.py startproject mysite 2, 项目结构如下: mysite ├── manage.py └── mysite ├── __init__.py ├── settings.py ├── urls.py └── wsgi.py manage.py ----- Django项目里面的工具,通过它可以调用django shell和数据库等。 settings.py ---- 包含了项目的默认设置,包括数据库信息,调试标志以及其他一些工作的变量。 urls.py ----- 负责把URL模式映射到应用程序。 二 ,运行开发服务器 要马上查看django项目应用的运行,可以使用Django项目里的mange.py 切换到工程目录,执行运行服务器命令: python manage.py runserver 完成: 打开浏览器,输入访问地址:127.0.0.1:8000 三,创建Blog应用 python manage.py startapp blog blog应用文件结构如下: ├── blog │   ├── admin.py │   ├── __init__.py │   ├── models.py │   ├── tests.py │   └── views.py 四,设计你的Model 在blog目录下的models.py是blog应用的核心文件之一,是定义blog数据结构的地方。 用编辑器打开models.py 新添加BlogPost类,代码如下: fromdjango.db importmodels # Create your models here. classBlogPost(models.Model): title =models.CharField(max_length =150) body =models.TextField() timestamp =models.DateTimeField() BlogPost类是django.db.models.Model的一个子类 。它有变量title(blog的标题),body(blog的内容部分),timestamp(blog的发表时间)。 五,设置数据库 Dajango支持主流的数据库服务器(MySQL,PostgreSQL,Oracle和MSSQL),但本项目使用SQLite,这里之需要通过一条简单的命令可以创建SQLite数据库。 创建数据库: 切换到工程主目录mysite/下,执行如下命令: <span style="font-family:Consolas, 微软雅黑, monospace, Verdana, sans-serif, 宋体"><span style="font-size: 12px;">python manage.py syncdb<br></span></span> 出现下面的提示,输入yes,然后按照提示输入相关的信息。完成后会生成一个数据库文件db.sqlite3 六,设置自动admin应用 1,打开mysite/mysite/urls.py,取消注释url(r'^admin/', include(admin.site.urls)) 2,编辑mysite/mysite/settings.py,在INSTALLED_APPS里面添加blog应用。 添加后的代码如下: <span style="font-family:Consolas, 微软雅黑, monospace, Verdana, sans-serif, 宋体"><span style="font-size: 12px;"># Application definition INSTALLED_APPS = (    'django.contrib.admin',    'django.contrib.auth',    'django.contrib.contenttypes',    'django.contrib.sessions',    'django.contrib.messages',    'django.contrib.staticfiles',    'blog', )<br></span></span> 2,修改mysite/blog/models.py 在最后添加一行代码: 1    <span style="font-family:Consolas, 微软雅黑, monospace, Verdana, sans-serif, 宋体"><span style="font-size: 12px;">admin.site.register(BlogPost)<br></span></span> models.py完整的代码如下: fromdjango.db importmodels fromdjango.contrib importadmin # Create your models here. classBlogPost(models.Model): title =models.CharField(max_length =150) body =models.TextField() timestamp =models.DateTimeField() admin.site.register(BlogPost) 3 ,打开浏览器,输入http://127.0.0.1:8000/admin/,输入刚才创建数据库时候填写的帐号就能进入admin界面。 七,试用admin 1, 点击Blog Posts右侧的Add 按钮,添加一个帖子。 2,让admin的BlogPost界面更加美观 修改blog应用的models.py,为它添加一个admin.ModelAdmin的子类BlogPostAdmin.以列表形式显示BlogPost的标题和时间。 fromdjango.db importmodels fromdjango.contrib importadmin # Create your models here. classBlogPost(models.Model): title =models.CharField(max_length =150) body =models.TextField() timestamp =models.DateTimeField() classBlogPostAdmin(admin.ModelAdmin): list_display =('title','timestamp') admin.site.register(BlogPost,BlogPostAdmin) 八,建立Blog的公共部分 从Django的角度看,一个页面具有三个典型的组件: 一个模板(template):模板负责把传递进来的信息显示出来。 一个视图(viw):视图负责从数据库获取需要显示的信息。 一个URL模式:它负责把收到的请求和你的试图函数匹配,有时候也会向视图传递一些参数。 1,创建模板 在blog目录下建立template目录(mysite/blog/templates),创建模板文件archive.html,它的内容如下: {% for post in posts %} <h2>{{ post.title }}</h2> <p>{{ post.timestamp }}</p> <p>{{ post.body }}</p> {% endfor%} 2,创建一个视图函数 在app应用的目录下的view.py添加视图函数 fromdjango.shortcuts importrender fromdjango.template importloader,Context fromdjango.http importHttpResponse fromblog.models importBlogPost # Create your views here. defarchive(request): posts =BlogPost.objects.all() t =loader.get_template("archive.html") c =Context({'posts':posts}) returnHttpResponse(t.render(c)) posts = BlogPost.objects.all() :获取数据库里面所拥有BlogPost对象 t = loader.get_template("archive.html"):加载模板 c = Context({'posts':posts}):模板的渲染的数据是有一个字典类的对象Context提供,这里的是一对键值对。 3,创建一个URL模式 第一步,在mysite/urls.py里面取消下面的一行注释: # 把它变成: url(r'^blog/', include('blog.urls')), 第二步:在blog应用里面定义URL,创建一个urls.py(mysite/blog/urls.py) fromdjango.conf.urls import* fromblog.views importarchive urlpatterns =patterns('', url(r'^$',archive), ) 最后,在浏览器输入如下地址http://127.0.0.1:8000/blog/ 九,最后的润色 1,模板的精确定位 在mysite/blog/templates目录里创建一个叫base.html的模板 <html> <styletype="text/css"> body{color:#efd;background:#453;padding:0 5em;margin:0} h1{padding:2em 1em;background:#675} h2{color:#bf8;border-top:1px dotted #fff;margin-top:2em} p{margin:1em 0} </style> <body> <h1>my blog</h1> {% block content %} {% endblock %} </body> </html> 2,修改archive.html模板,让它引用base.html模板和它的“content”块。 {%extends "base.html"%} {%block content %} {%forpost inposts %} <h2>{{  post.title }}</h2> <p>{{ post.timestamp | date:"1,F jS"}}</p> <p>{{ post.body }}</p> {%endfor %} {%endblock %} 刷新浏览器可以看到效果如下: 3,按日期排序 修改blog 应用下的models.py,为BlogPost添加一个Meta嵌套类。如下: <span style="font-size: 12px;">classBlogPost(models.Model): title =models.CharField(max_length =150) body =models.TextField() timestamp =models.DateTimeField() classMeta: ordering =('-timestamp',)<br></span> 刷新浏览器,如下:

(0)

相关推荐

  • APMServ一键快速搭建Apache+PHP+MySQL+Nginx+Memcached+ASP运行平台教程

    对于很多刚学习建站的新手,都有着这样的苦恼,PHP程序越来越多,而且大部分都是开源,想学习php或用php程序建站,可看着php运行环境的设置,就不知道从何下手,和IIS设置不一样,php运行环境的软 ...

  • 如何免费快速搭建一个仓库管理系统?

    库房进货.提货.备货混乱,想纸笔记录,发现工作量太大:改用Excel,发现数据难同步:想自己搭建系统,不会编程.更没有--作为没有的新手,到底该如何快速搭建一个实用的仓库管理系统? 操作方法 01 在 ...

  • 在EXCEL中快速制作简单的流程图

    日常工作和编程中会经常使用流程图,那么如何运用EXCEL的功能快速制作呢?下面小编就为大家详细介绍一下,来看看吧! 方法/步骤 打开编辑表格. 依次选择[插入]-[插图]-[SmartArt]选项. ...

  • 怎样用博瑞微传媒建站快车快速搭建网站?

    网站搭建的方法有传统的网站设计及编程开发,也有DIY模块化的自助建站平台,今天博瑞微传媒小编给大家介绍的网站搭建平台,可以直接套用近千套建站模板,DIY模块化式快速搭建自己的网站,即适合会网站设计及编 ...

  • 快速搭建属于自己的秒赞网

    秒赞是提升自己人气的好帮手,但是很多人都不知道怎么来搭建,现在来教你快速搭建稳定而且访问速度快的秒赞网,成本很低,可能也就是一包烟不到的花费. 操作方法 01 虚拟主机和域名肯定得买好,没必要去比较大 ...

  • PHP服务器环境如何简单快速搭建?:[1](一)

    一般要搭建PHP服务器环境需要在windows下安装apache php mysql,更需要从各官方网站下下载apache, php, mysql相关软件,非常的麻烦,今天教大家一个快速简单搭建PHP ...

  • linux的ubuntu和centos下快速搭建LAMP环境

    在linux下安装lamp环境,下面为大家分别介绍在ubuntu和centos下面快速安装LAMP环境的方法。 首先,让我们了解一下什么是LAMP环境(一下摘自百度百科): Linux+Apache+ ...

  • win7怎样快速搭建局域网?

    今天和小伙伴们联机玩游戏,发现很多小伙伴并清楚该怎样搭建局域网. 网上很多方法在教人们怎样建立局域网,但很多方法都是教你先怎样制作双绞线.直通线,然后怎样配ip,怎样用黑框测是否连通...小编认为,这 ...

  • 快速搭建PHP本地服务器

    PHP 是一种免费开源的服务器端脚本程序,是HTML的嵌入式语言,它使用广泛,主要适用于Web开发领域.但是,它做为服务器端脚本程序,也只能在服务器端允许后返回HTML信息,要正确的搭建PHP服务器其 ...