zoukankan      html  css  js  c++  java
  • django(一)

     Django 自称是“最适合开发有限期的完美WEB框架”。本文参考《Django web开发指南》,快速搭建一个blog 出来,在中间涉及诸多知识点,这里不会详细说明,如果你是第一次接触Django ,本文会让你在感性上对Django有个认识,完成本文操作后会让你有兴趣阅读的相关书籍和文档。

    废话少说,come on!!

    本操作的环境:

    ===================

    Windows 7/10

    python 2.7

    Django 1.8.2

    ===================

     

     

     创建工程                                                                                                          

     

    创建mysite工程项目:

    D:/djpy> django-admin.py startproject mysite

    工程目录结构:

    manage.py ----- Django项目里面的工具,通过它可以调用django shell和数据库等。

    settings.py ---- 包含了项目的默认设置,包括数据库信息,调试标志以及其他一些工作的变量。

    urls.py ----- 负责把URL模式映射到应用程序。

     

     

    创建blog应用                                                                                                   

     

    在mysite目录下创建blog应用

    
    
    D:/pydj> cd mysite
    D:/djpy/mysite$ python manage.py startapp blog

    目录结构:

     

    初始化admin后台数据库                                                                                                

     

      python 自带SQLite数据库,Django支持各种主流的数据库,这里为了方便推荐使用SQLite,如果使用其它数据库请在settings.py文件中设置。

    切换到mysite创建数据库:

    复制代码
    D:/djpy/mysite$ python manage.py syncdb    command is deprecated in django 1.7. Use the python manage.py migrate instead.

    C:Python27libsite-packagesdjangocoremanagementcommandssyncdb.py:24: RemovedInDjango19Warning: The syncdb command will be removed in Django 1.9
    warnings.warn("The syncdb command will be removed in Django 1.9", RemovedInDjango19Warning)

    
    

    Operations to perform:
    Synchronize unmigrated apps: staticfiles, messages
    Apply all migrations: admin, contenttypes, auth, sessions
    Synchronizing apps without migrations:
    Creating tables...
    Running deferred SQL...
    Installing custom SQL...
    Running migrations:
    Rendering model states... DONE
    Applying contenttypes.0001_initial... OK
    Applying auth.0001_initial... OK
    Applying admin.0001_initial... OK
    Applying contenttypes.0002_remove_content_type_name... OK
    Applying auth.0002_alter_permission_name_max_length... OK
    Applying auth.0003_alter_user_email_max_length... OK
    Applying auth.0004_alter_user_username_opts... OK
    Applying auth.0005_alter_user_last_login_null... OK
    Applying auth.0006_require_contenttypes_0002... OK
    Applying sessions.0001_initial... OK

    
    

    You have installed Django's auth system, and don't have any superusers defined.
    Would you like to create one now? (yes/no): yes
    Username (leave blank to use 'fnngj'):    用户名(默认当前系统用户名)
    Email address: fnngj@126.com     邮箱地址
    Password:     密码
    Password (again):    重复密码
    Superuser created successfully.

    复制代码

    设置admin应用                                                                                    

      

      admin 是Django 自带的一个后台管理系统。

    1、添加blog应用,打开mysite/mysite/settings.py 文件:

    复制代码
    # Application definition
    
    INSTALLED_APPS = (
        'django.contrib.admin',
        'django.contrib.auth',
        'django.contrib.contenttypes',
        'django.contrib.sessions',
        'django.contrib.messages',
        'django.contrib.staticfiles',
        'blog',
    )
    复制代码

     在列表末尾,添加blog 应用

     

    2、在我们创建django项目时,admin就已经创建,打开mysite/mysite/urls.py文件:

    复制代码
    from django.conf.urls import include, url
    from django.contrib import admin
    
    urlpatterns = [
        url(r'^admin/', include(admin.site.urls)),
    ]
    复制代码

    3、启动django容器

    复制代码
    D:pydjmysite>python manage.py runserver
    Performing system checks...
    
    System check identified no issues (0 silenced).
    October 04, 2015 - 20:56:45
    Django version 1.8.2, using settings 'mysite.settings'
    Starting development server at http://127.0.0.1:8000/
    Quit the server with CTRL-BREAK.
    复制代码

      

    4、访问后台应用

    http://127.0.0.1:8000/admin

     

     输入用户、密码,用户名密码为第一次创建数据库时创建的。回想“设置数据库”时的设置。

     

     

    设计Model(即设计数据库表)                                  

     

    1、设计model

      现在我们打开blog目录下的models.py文件,这是我们定义blog数据结构的地方。打开mysite/blog/models.py 文件进行修改:

    复制代码
    from django.db import models
    from django.contrib import admin
    
    # Create your models here.
    class BlogsPost(models.Model):
        title = models.CharField(max_length = 150)
        body = models.TextField()
        timestamp = models.DateTimeField()
    
    admin.site.register(BlogsPost)
    复制代码

    2、 再次初始化数据库

    复制代码
    D:pydjmysite>python manage.py makemigrations blog
    Migrations for 'blog':
      0001_initial.py:
        - Create model BlogsPost
    
    D:pydjmysite>python manage.py syncdb
    C:Python27libsite-packagesdjangocoremanagementcommandssyncdb.py:24: RemovedInDjango19Warning: The syncdb command will be removed in Django 1.9
      warnings.warn("The syncdb command will be removed in Django 1.9", RemovedInDjango19Warning)
    
    Operations to perform:
      Synchronize unmigrated apps: staticfiles, messages
      Apply all migrations: admin, blog, contenttypes, auth, sessions
    Synchronizing apps without migrations:
      Creating tables...
        Running deferred SQL...
      Installing custom SQL...
    Running migrations:
      Rendering model states... DONE
      Applying blog.0001_initial... OK
    复制代码

    3、再次runserver启动服务,访问admin后台,创建文章。

      登陆成功选择add 创建博客

    输入博客标题,正文、日期时间、点击save 创建博客。

     

     

     

    设置admin 的BlogsPost界面                                                              

     

      打开mysite/blog/models.py 文件,做如下修改:

    复制代码
    from django.db import models
    from django.contrib import admin
    
    # Create your models here.
    class BlogsPost(models.Model):
        title = models.CharField(max_length = 150)
        body = models.TextField()
        timestamp = models.DateTimeField()
    
    class BlogPostAdmin(admin.ModelAdmin):
        list_display = ('title','timestamp')
        
    admin.site.register(BlogsPost,BlogPostAdmin)
    复制代码

    创建BlogPostAdmin类,继承admin.ModelAdmin父类,以列表的形式显示BlogPost的标题和时间。

     

     

    创建blog的公共部分

    从Django的角度看,一个页面具有三个典型的组件:

    一个模板(template):模板负责把传递进来的信息显示出来。

    一个视图(view):视图负责从数据库获取需要显示的信息。

    一个URL模式:它负责把收到的请求和你的试图函数匹配,有时候也会向视图传递一些参数。

     

     

    创建模板                                                                                                  

     

    在blog项目下创建templates目录(mysite/blog/templates/),在目录下创建模板文件index.html,内容如下:

    {% for post in posts %}
        <h2>{{ post.title }}</h2>
        <p>{{ post.timestamp }}</p>
        <p>{{ post.body }}</p>
    {% endfor%}

     

    创建视图函数                                                                                          

     

    打开mysite/blog/views.py文件:

    复制代码
    #coding=utf-8
    from django.shortcuts import render
    from blog.models import BlogsPost
    from django.shortcuts import render_to_response
    
    # Create your views here.
    def index(request):
        blog_list = BlogsPost.objects.all()
        return render_to_response('index.html',{'blog_list':blog_list})
    复制代码

    blog_list = BlogPost.objects.all() :获取数据库里面所拥有BlogPost对象

    render_to_response()返回一个页面(index.html),顺带把数据库中查询出来的所有博客内容(blog_list)也一并返回。

     

     

    创建blog的URL模式                                                                             

     

    在mysite/urls.py文件里添加blog的url:

    复制代码
    #coding=utf-8
    from django.conf.urls import patterns, include, url
    from django.contrib import admin
    
    urlpatterns = patterns('',
        url(r'^admin/', include(admin.site.urls)),
        url(r'^index/$', 'blog.views.index'),
    )
    复制代码

    再次启动服务($ python manage.py runserver),访问blog应用(http://127.0.0.1:8000/index/)下图有错,仅供参考。

    页面如下:

    当然,读者可以继续到admin后台添加blog,从而刷新这个页是否显示新添加的blog。

     

     

    添加样式                                                                                                    

     

    创建基础模板

    在mysite/blog/templates目录里创建base.html的模板:

    复制代码
    <html>
          <style type="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>虫师blog</h1>
            <h3>大人不华,君子务实</h3>
            {% block content %}
            {% endblock %}
          </body>
    </html>
    复制代码

     

    修改index.html模板,让它引用base.html模板和它的“content”块。

    复制代码
    {% extends "base.html" %}
      {% block content %}
          {% for post in posts %}
          <h2>{{  post.title }}</h2>
          <p>{{ post.timestamp | date:"1,F jS"}}</p>
          <p>{{ post.body }}</p>
          {% endfor %}
      {% endblock %}
    复制代码

    再次刷新博客页面:

    http://127.0.0.1/index/   下图有错,仅供参考。

      请系统的学习django web框架,然后在此基础上做更多的扩展,开发自己真正的blog 。

  • 相关阅读:
    HashMap底层实现原理/HashMap与HashTable区别/HashMap与HashSet区别(转)
    JSP语法
    Web开发基础(读书笔记)
    eclispe新导入的文件有个小红叉号(x)的问题
    Vue处理数据,数组更新,但视图无法得到及时更新
    VUE 利用tab切换+同路由跳转传参(check)+vant上拉加载制作订单列表(终)
    适配方案一之:利用rem和less计算制作移动端适配页面
    Git常用命令务忘
    git提交代码步骤笔记
    Vue仿淘宝订单状态的tab切换效果——(但现实中不会用此种方式进行存储数据)
  • 原文地址:https://www.cnblogs.com/AmilyWilly/p/6229942.html
Copyright © 2011-2022 走看看