django基础 (三)博客页面开发以及修改文章的功能实现

页面概要 :博客主页面 博客文章内容页面 博客撰写页面

主页面内容: 文章标题列表,超链接; 发表博客按钮(超链接)

列表编写思路: 取出数据库中所有文章对象;
将文章对象们打包成列表,传递到前端;
前端页面把文章以标题超链接的形式逐个列出

模板For循环
{% for xx in xxs %}
HTML语句
{% endfor %}

这里,我们在前两章所做项目基础上完成博客页面开发;
编辑views.py

def index(request):
    articles = models.Article.objects.all() # 获取所有, all()返回的是查询的一个集合
    return render(request, 'index.html', {'articles': articles})

编辑index.html

<h1>
    <a href="">新文章</a>
</h1>
{% for article in articles %}
    <a href="">{{ article.title }}</a>
    <br/>
{% endfor %}

运行:
pycharm里可以之间按alt+shift+x来运行项目。

博客文章页面: 页面内容 标题; 文章内容; 修改文章按钮(超链接);

编辑views.py,get用户点击文章标题返回的pk

def article_page(request, article_id):
    article = models.Article.objects.get(pk=article_id)
    return render(request, 'article_page.html', {'article': article})

制作文章页面html,创建article_page.html

<h1>{{ article.title }}</h1>
<br/><br/>
<a href="">修改文章</a>

配置url
打开应用下的urls.py
用到正则匹配数字,在django2.x中需要用到re_path。
django 1.x

url(r'^article/(?P<article_id>[0-9]+)$', views.article_page),

django 2.x

from django.urls import re_path
re_path('article/(?P<article_id>[0-9]+)', views.article_page),

django中的超链接

超链接模板地址

  • href后面是模板地址;
  • template中可以用 “{% url ‘app_name:url_name’ param %}”
  • 其中app_name 和 url_name都在url中配置

再配URL,使主页面点击文章title可跳转至相应页面:
打开项目根目录下的urls.py,修改第二条;

path('index/', include('newApp.urls', namespace='newApp')),    # django 1.x

path('index/', include(('newApp.urls', 'newApp'), namespace='newApp')),    # django 2.x

打开应用下的urls.py

re_path('article/(?P<article_id>[0-9]+)', views.article_page, name='article_page'),

index.html,添加{{article.title}}的href

<a href="{% url 'newApp:article_page' article.id %}">{{ article.title }}</a>

博客撰写页面

页面内容:标题编辑栏、文章内容编辑区域、提交按钮;
创建edit_page.html

{#url: 首先寻找项目目录下的urls.py下的namespace为newApp,然后是指引过去的urls.py的name,用冒号表示两者关系#}
<form action="{% url 'newApp:edit_action' %}" method="post">

    <!-- POST请求的表单内需要加上下面这句话,否则将禁止访问 -->
    {% csrf_token %}

    <label>文章标题
        <input type="text" name="title">
    </label>
    <br/>
    <label>文章内容
        <input type="text" name="content">
    </label>
    <br/>
    <input type="submit">
</form>

编辑views函数,url基础配置;

def edit_page(request):
    return render(request, 'edit_page.html')

def edit_action(request):

    # 获取用户提交的POST请求中name="title",name="content"的信息
    title = request.POST.get('title', 'TITLE')
    content = request.POST.get('content', 'CONTENT')

    # 将用户提交的信息存储到数据库中
    models.Article.objects.create(title=title, content=content)

    # 提交后返回至主页
    articles = models.Article.objects.all()
    return render(request, 'index.html', {'articles': articles})


path('edit/', views.edit_page, name='edit_page'),
path('edit/action', views.edit_action, name='edit_action'),

编辑响应函数:使用requestPOST[‘参数名’]获取表单数据;再存储至数据库;

def edit_page(request):
    return render(request, 'edit_page.html')

def edit_action(request):

    # 获取用户提交的POST请求中name="title",name="content"的信息
    title = request.POST.get('title', 'TITLE')
    content = request.POST.get('content', 'CONTENT')

    # 将用户提交的信息存储到数据库中
    models.Article.objects.create(title=title, content=content)

    # 提交后返回至主页
    articles = models.Article.objects.all()
    return render(request, 'index.html', {'articles': articles})

主页配置撰写页面的超链接

<a href="{% url 'newApp:edit_page' %}">写文章</a>

实现修改文章的功能

思路: 新文章为空,修改文章有内容; 修改文章页面有文章对象; 文章的ID

编辑views响应函数:

def edit_page(request, article_id):
    if str(article_id) == '0':
        return render(request, 'edit_page.html')
    article = models.Article.objects.get(pk=article_id)
    return render(request, 'edit_page.html', {'article': article})

def edit_action(request):

    # 获取用户提交的POST请求中name="title",name="content"的信息
    title = request.POST.get('title', 'TITLE')
    content = request.POST.get('content', 'CONTENT')

    # 添加了修改文章功能,设置提交按钮的判断
    # 根据id判断是新建文章返回至主页,修改文章的提交返回至文章页面
    article_id = request.POST.get('article_id', '0 ')
    if article_id =='0':

        # 将用户提交的信息存储到数据库中
        models.Article.objects.create(title=title, content=content)

        # 提交后返回至主页
        articles = models.Article.objects.all()
        return render(request, 'index.html', {'articles': articles})

    article = models.Article.objects.get(pk=article_id)
    article.title = title
    article.content = content
    article.save()
    return render(request, 'article_page.html', {'article': article})

编辑html页面:

{# edit_page.html #}
{#url: 首先寻找项目目录下的urls.py下的namespace为newApp,然后是指引过去的urls.py的name,用冒号表示两者关系#}
<form action="{% url 'newApp:edit_action' %}" method="post">

    <!-- POST请求的表单内需要加上下面这句话,否则将禁止访问 -->
    {% csrf_token %}
{#    页面上点击‘修改文章’,判断如果有article,将title的value设置成相应的title,没有则为空#}
    {% if article %}
        <input type="hidden" name="article_id" value="{{ article.id }}">
        <label>文章标题
            <input type="text" name="title" value="{{ article.title }}">
        </label>
        <br/>
        <label>文章内容
            <input type="text" name="content" value="{{ article.content }}">
        </label>
        <br/>

    {% else  %}
        <input type="hidden" name="article_id" value="0">
        <label>文章标题
            <input type="text" name="title">
        </label>
        <br/>
        <label>文章内容
            <input type="text" name="content">
        </label>
        <br/>
    {% endif %}

    <input type="submit">
</form>



{#article_page.html#}
<h1>{{ article.title }}</h1>
<br/><br/>
<h3>{{ article.content }}</h3>
<a href="{% url 'newApp:edit_page' article.id %}">修改文章</a>



{#index.html#}
<h1>
    <!-- 设置新文章url为0 -->
    <a href="{% url 'newApp:edit_page' 0 %}">写文章</a>
</h1>
<br/>
{% for article in articles %}
    <a href="{% url 'newApp:article_page' article.id %}">{{ article.title }}</a>
    <hr/>
{% endfor %}

url配置:

re_path('edit/(?P<article_id>[0-9]+)', views.edit_page, name='edit_page'),

OK。

  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
基于python3.8和Django3.0的博客 文章,页面,分类目录,标签的添加,删除,编辑等。文章及页面支持Markdown,支持代码高亮。 支持文章全文搜索。 完整的评论功能,包括发表回复评论,以及评论的邮件提醒,支持Markdown。 侧边栏功能,最新文章,最多阅读,标签云等。 支持Oauth登陆,现已有Google,GitHub,facebook,微博,QQ登录。 支持Memcache缓存,支持缓存自动刷新。 简单的SEO功能,新建文章等会自动通知Google和百度。 集成了简单的图床功能。 集成django-compressor,自动压缩css,js。 网站异常邮件提醒,若有未捕捉到的异常会自动发送提醒邮件。 集成了微信公众号功能,现在可以使用微信公众号来管理你的vps了。 安装 mysql客户端从pymysql修改成了mysqlclient,具体请参考 pypi 查看安装前的准备。 使用pip安装: pip install -Ur requirements.txt 如果你没有pip,使用如下方式安装: OS X / Linux 电脑,终端下执行: curl http://peak.telecommunity.com/dist/ez_setup.py | python curl https://raw.github.com/pypa/pip/master/contrib/get-pip.py | python Windows电脑: 下载 http://peak.telecommunity.com/dist/ez_setup.py 和 https://raw.github.com/pypa/pip/master/contrib/get-pip.py 这两个文件,双击运行。 配置 配置都是在 setting.py ,部分配置迁移到了后台配置。 很多 setting 配置我都是写在环境变量里面的.并没有提交到 github 来.例如SECRET_KEY,OAHUTH,mysql以及邮件部分的配置等.你可以直接修改代码成你自己的,或者在环境变量里面加入对应的配置就可以了. test目录的文件都是为了travis自动化测试使用的.不用去关注.或者直接使用.这样就可以集成travis自动化测试了. bin目录是在linux环境使用Nginx+Gunicorn+virtualenv+supervisor来部署的脚本和Nginx配置文件.可以参考我的文章: DjangoBlog部署教程 有详细的部署介绍. 运行 修改DjangoBlog/setting.py 修改数据库配置,如下所示: DATABASES = { 'default': { 'ENGINE': 'django.db.backends.mysql', 'NAME': 'djangoblog', 'USER': 'root', 'PASSWORD': 'password', 'HOST': 'host', 'PORT': 3306, } } 创建数据库 mysql数据库执行: CREATE DATABASE `djangoblog` /*!40100 DEFAULT CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci */; 然后终端下执行: ./manage.py makemigrations ./manage.py migrate 注意: 在使用 ./manage.py 之前需要确定你系统的 python 命令是指向 python 3.6 及以上版本的。如果不是如此,请使用以下两种方式的一种: 修改 manage.py 第一行 #!/usr/bin/env python 为 #!/usr/bin/env python3 直接使用 python3 ./manage.py makemigrations 创建超级用户 终端下执行: ./manage.py createsuperuser 创建测试数据 终端下执行: ./manage.py create_testdata 收集静态文件 终端下执行: ./manage.py collectstatic --noinput ./manage.py compress --force 开始运行: 执行: ./manage.py runserver 浏览器打开: http://127.0.0.1:8000/ 就可以看到效果了。
完整版:https://download.csdn.net/download/qq_27595745/89522468 【课程大纲】 1-1 什么是java 1-2 认识java语言 1-3 java平台的体系结构 1-4 java SE环境安装和配置 2-1 java程序简介 2-2 计算机的程序 2-3 java程序 2-4 java类库组织结构和文档 2-5 java虚拟机简介 2-6 java的垃圾回收器 2-7 java上机练习 3-1 java语言基础入门 3-2 数据的分类 3-3 标识符、关键字和常量 3-4 运算符 3-5 表达式 3-6 顺序结构和选择结构 3-7 循环语句 3-8 跳转语句 3-9 MyEclipse工具介绍 3-10 java基础知识章节练习 4-1 一维数组 4-2 数组应用 4-3 多维数组 4-4 排序算法 4-5 增强for循环 4-6 数组和排序算法章节练习 5-0 抽象和封装 5-1 面向过程的设计思想 5-2 面向对象的设计思想 5-3 抽象 5-4 封装 5-5 属性 5-6 方法的定义 5-7 this关键字 5-8 javaBean 5-9 包 package 5-10 抽象和封装章节练习 6-0 继承和多态 6-1 继承 6-2 object类 6-3 多态 6-4 访问修饰符 6-5 static修饰符 6-6 final修饰符 6-7 abstract修饰符 6-8 接口 6-9 继承和多态 章节练习 7-1 面向对象的分析与设计简介 7-2 对象模型建立 7-3 类之间的关系 7-4 软件的可维护与复用设计原则 7-5 面向对象的设计与分析 章节练习 8-1 内部类与包装器 8-2 对象包装器 8-3 装箱和拆箱 8-4 练习题 9-1 常用类介绍 9-2 StringBuffer和String Builder类 9-3 Rintime类的使用 9-4 日期类简介 9-5 java程序国际化的实现 9-6 Random类和Math类 9-7 枚举 9-8 练习题 10-1 java异常处理 10-2 认识异常 10-3 使用try和catch捕获异常 10-4 使用throw和throws引发异常 10-5 finally关键字 10-6 getMessage和printStackTrace方法 10-7 异常分类 10-8 自定义异常类 10-9 练习题 11-1 Java集合框架和泛型机制 11-2 Collection接口 11-3 Set接口实现类 11-4 List接口实现类 11-5 Map接口 11-6 Collections类 11-7 泛型概述 11-8 练习题 12-1 多线程 12-2 线程的生命周期 12-3 线程的调度和优先级 12-4 线程的同步 12-5 集合类的同步问题 12-6 用Timer类调度任务 12-7 练习题 13-1 Java IO 13-2 Java IO原理 13-3 流类的结构 13-4 文件流 13-5 缓冲流 13-6 转换流 13-7 数据流 13-8 打印流 13-9 对象流 13-10 随机存取文件流 13-11 zip文件流 13-12 练习题 14-1 图形用户界面设计 14-2 事件处理机制 14-3 AWT常用组件 14-4 swing简介 14-5 可视化开发swing组件 14-6 声音的播放和处理 14-7 2D图形的绘制 14-8 练习题 15-1 反射 15-2 使用Java反射机制 15-3 反射与动态代理 15-4 练习题 16-1 Java标注 16-2 JDK内置的基本标注类型 16-3 自定义标注类型 16-4 对标注进行标注 16-5 利用反射获取标注信息 16-6 练习题 17-1 顶目实战1-单机版五子棋游戏 17-2 总体设计 17-3 代码实现 17-4 程序的运行与发布 17-5 手动生成可执行JAR文件 17-6 练习题 18-1 Java数据库编程 18-2 JDBC类和接口 18-3 JDBC操作SQL 18-4 JDBC基本示例 18-5 JDBC应用示例 18-6 练习题 19-1 。。。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值