python关于Django搭建简单博客项目(详解一)

上一篇我们说了如何搭建简易博客网站,下面我们来进行详细解答。本文没有特定顺序,请结合上一篇和源代码参照学习。
相关源代码和解析请参看:https://github.com/Cheng0829/mysite

/mysite/manage.py(Django项目里面的工具,通过它可以调用django shell和数据库等)
/mysite/mysite/settings.py(包含了项目的默认设置,包括数据库信息,调试标志以及其他一些工作的变量)
/mysite/mysite/urls.py(负责把URL模式映射到应用程序,通俗理解就是网址)

在blog目录下的models.py是blog应用的核心文件之一,是定义blog数据结构的地方。修改models.py,新添加BlogPost类,代码如下:

from django.db import models
class BlogPost(models.Model):
    title = models.CharField(max_length = 150)(长度确定)
    body = models.TextField()(长度不定,可以无限)
    timestamp = models.DateTimeField()

XXXField:字段类型(Field types)
BlogPost类是django.db.models.Model的一个子类 。它有变量title(blog的标题),body(blog的内容部分),timestamp(blog的发表时间)。

CharField:
      class CharField(max_length=None,[**options])

CharField是一个字符串字段,对小字符串和大字符串都适用。对于更大的文本,应该使用TextField 。
但它有一个必须传入的参数:max_length,字段的最大字符数。

DateTimeField
     class DateTimeField([auto_now=False, auto_now_add=False, **options])

DateTimeField利用 datetime.datetime 实例表示日期和时间。

TextField
     class TextField([**options])         

#TextField用于处理大文本字段,理论上可无限。

接下来,先python manage.py makemigrations(简历mysite)
然后python manage.py migrate(创建SQLite数据库,数据库迁移,migrate意为迁移)
最后在根目录mysite下生成一个数据库文件db.sqllite3。

打开mysite/mysite/urls.py,写上url(r’^admin/‘, admin.site.urls),使此地址可以打开admin后台
urlpatterns = [
url(‘admin/’, admin.site.urls),
url(r’^blog/$',views.blog_index,name=‘index’),
]

编辑mysite/mysite/settings.py,在INSTALLED_APPS列表里面添加blog应用(列表也可以用逗号结尾)

(若需要改变时区和语言,则在107,109行改代码为
LANGUAGE_CODE = ‘zh-hans’(默认为en-us),TIME_ZONE = ‘Asia/Shanghai’(默认为UTC))

(在setting.py第26行有DEBUG=True,故在打开某不存在页面时,显示“Page Not Found”,而不是404)

DEBUG = True   
ALLOWED_HOSTS = []

#若把DEBUG变量注释掉或设为False,必须在ALLOWED_HOSTS不为空, 此时打开某不存在页面,显示Sever Error 500
#404:找不到文件 500:内部服务器错误

code:代码,编码

此时输入http://127.0.0.1:8000/admin/,输入刚才创建数据库时候填写的帐号就能进入admin界面

从Django的角度看,一个页面具有三个典型的组件:
1.模板(model):模板负责把传递进来的信息显示出来。
2.视图(view):视图负责从数据库获取需要显示的信息。
3.URL模式:它负责把收到的请求和你的试图函数匹配,有时候也会向视图传递一些参数。
其实前面的步骤而言,我们已经是完成了model这个模块的功能了,接下来就是做好视图的映射就可以了。

下面解析index.html:
渲染变量使用双大括号{{ }},渲染标签则使用双大括号{% %}

templates中html文件的for标签:
{% for i in blog_list %}  #blog_list 为后端传递给模板的变量

<p>{{ blog.XXX }}</p>  #输出blog.XXX,若把p改为h2,可把把字体加粗,然后加大到2号(数字越小字越大)

{% endfor %}       #使用endfor来表示循环结束

接下来编写views.py:

from django.shortcuts import render
from blog.models import BlogsPost
def blog_index(request):
    blog_list = BlogsPost.objects.all()   # 从数据库获取所有该类对象,即获取所有数据
    return render(request, 'index.html', {'blog_list':blog_list})

render方法可接收三个参数,一是request参数,二是待渲染的html模板文件,三是保存具体数据的字典参数。它的作用就是将数据填充进模板文件,最后把结果返回给浏览器。

修改mysite/mysite/urls.py:
其中,r’^blog/$’表示地址为127.0.0.1:8000/blog,views.blog_index是引用views中的blog_index函数,利用html文件,name =‘index’
说明利用的是index.html文件,urlpatterns是个列表。

mysite文件夹中核心文件是setting.py,这也是最复杂最难读懂的一个py文件,所以下一篇我们讲解setting.py。

相关源代码和解析请参看:https://github.com/Cheng0829/mysite

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值