Django搭建博客网站(四)

Django搭建博客网站(四)

最后一篇主要讲讲在后台文章编辑加入markdown,已经在文章详情页对markdown的解析.

Django搭建博客网站(一)

Django搭建博客网站(二)

Django搭建博客网站(三)

要用到的package

  • django-pagedown
  • markdown2

django-pagedown用来在后台生成markdown编辑器,markdown2则是用来将markdown解析成html显示在网页上.

install

$ pip install django-pagedown
$ pip install markdown2

后台markdown编辑器

使用django-pagedown之前,去它的github地址看了一下.

  1. Get the code: pip install django-pagedown
  2. Add pagedown to your INSTALLED_APPS
  3. Make sure to collect the static files: python manage.py collectstatic --noinput (and if you are working in a development environment, make sure you are properly serving your static files)

    可以知道安装了package,还要将django-pagedown安装到项目中:

# settings.py
INSTALLED_APPS = [
    ‘pagedown‘,
    ‘post.apps.PostConfig‘,
    ‘django.contrib.admin‘,
    ‘django.contrib.auth‘,
    ‘django.contrib.contenttypes‘,
    ‘django.contrib.sessions‘,
    ‘django.contrib.messages‘,
    ‘django.contrib.staticfiles‘,
]

但是运行上面第三点里面的命令,出现了错误,最后上stackoverflow查了一下,原来是在settings.py里面还得添加设置:

# settings.py
BASE_DIR = os.path.dirname(os.path.dirname(os.path.abspath(__file__)))
STATIC_ROOT = os.path.normpath(os.path.join(BASE_DIR, ‘staticfiles‘))
STATICFILES_DIRS = (
    os.path.join(BASE_DIR, ‘static‘),
)

此时再运行python manage.py collectstatic --noinput就没问题了.

接下啦自然就是在后台添加markdown编辑器了,其实只需要让文章的内容部分支持markdown就行了,也就是post这个model里的post_content,修改admin.py文件就够了:

# admin.py
from django.contrib import admin
from .models import Post, PostTag
from pagedown.widgets import AdminPagedownWidget
from django import forms

class PostForm(forms.ModelForm):
    post_content = forms.CharField(widget=AdminPagedownWidget(show_preview=True))

    class Meta:
        model=Post
        fields=‘__all__‘

class PostAdmin(admin.ModelAdmin):
    form = PostForm
    filter_horizontal = (‘posttag‘,)

admin.site.register(Post,PostAdmin)
admin.site.register(PostTag)

show_preview设置成True会在编辑的时候显示预览.

此时运行项目再进后台,就能使用markdown编辑文章内容了.

markdown解析

当后台使用markdown编辑后,存入数据库的文章内容是markdown代码,直接传到网页上显示的话,也是显示的markdown代码.

在django里面允许每个app为模板添加过滤器.

这里就可以通过过滤器来实现使用markdown2对markdown的解析.

django的过滤器功能,在每个app的templatetags文件夹下面,需要自行创建,注意创建的时候是一个package,而不是dictionary,也就是包含一个__init__.py文件.

然后,在templatetags文件夹下面创建一个djangomarkdown.py:

# post/templatetags/djangomarkdown.py
import markdown2

from django import template
from django.template.defaultfilters import stringfilter
from django.utils.safestring import mark_safe

register = template.Library()

@register.filter(is_safe=True)
@stringfilter
def djangomarkdown(value):
    return mark_safe(markdown2.markdown(value,
                                        extras=["fenced-code-blocks", "cuddled-lists", "metadata","tables", "spoiler"]))

既然创建了一个过滤器,那么要怎么用呢?

其实是直接在html文件里边就可以用的,不过要先在html文件里面加载(以post.html为例):

{% extends ‘post/base.html‘ %}
{% load djangomarkdown %}
{% block title %}
    <title>{{ post.post_title }}</title>
{% endblock %}
{% block content %}
    <div class="container">
        <div class="page-header"><h1>{{ post.post_title }}</h1></div>
        <div class="description">
            <span class="col-md-2"><a href="{% url ‘post:user‘ ‘Chain‘ %}">Chain</a></span><span
                class="col-md-2">{{ post.pub_date }}</span>
            {% if post.pub_date < post.change_date %}
                <span class="col-md-4">last change:{{ post.change_date }}</span>
            {% endif %}
        </div>
        <br>
        <hr>
        <div class="content">
            {{ post.post_content|djangomarkdown }}
        </div>
        <br>
        <hr>
        <div class="btn-group" role="group" aria-label="...">
            {% for tag in post.posttag.all %}
                <a href="{% url ‘post:tag‘ tag.tag_name %}">
                    <button type="button" class="btn btn-info">#{{ tag.tag_name }}</button>
                </a>
            {% endfor %}
        </div>
    </div>
{% endblock %}

先在文件开头加载自定义的过滤器,然后html里面就可以直接使用了.

原文地址:https://www.cnblogs.com/gracelove/p/8284809.html

时间: 2024-10-03 23:53:14

Django搭建博客网站(四)的相关文章

Django搭建博客网站(三)

Django搭建博客网站(三) 第三篇主要记录view层的逻辑和template. Django搭建博客网站(一) Django搭建博客网站(二) 结构 网站结构决定我要实现什么view. 我主要要用view展示首页,标签页,网站管理员(也就是本人啦)信息页,以及文章详情页. settings.py 因为到这个阶段需要编写html文件了,但是每一个网页的每一行代码都靠自己去写,各种渲染也靠自己去写的话,太麻烦了,Django提供了html模板功能,可以在settings.py里面进行配置. #

Django搭建博客网站(二)

Django搭建自己的博客网站(二) 这里主要讲构建系统数据库Model. Django搭建博客网站(一) model 目前就只提供一个文章model和一个文章分类标签model,在post/models.py中做如下修改: # models.py from django.db import models class PostTag(models.Model): tag_name = models.CharField(max_length=50) def __str__(self): retur

Django搭建博客网站(一)

Django搭建自己的博客网站(一) 简介 这个系列主要是通过使用Django这个python web框架实现一个简单的个人博客网站.对Django有疑问可以上Django官网查文档. 功能 后台管理文章发布,修改,删除 分标签管理 依赖 除了使用Django以外,网页排版部分使用了Bootstrap框架,文章编辑器和解析器分别使用django-pagedown和markdown2. install $ pip install django $ pip install django-pagedw

Django 编写博客网站的用户管理部分(采用自有的 django.contrib.auth) 2. 登陆登出和用户信息管理

续前Django 编写博客网站的用户管理部分(采用自有的 django.contrib.auth) 1. 注册部分 项目工具:Python 2.7.11  Django 1.10.2  Bootstrap 3.3.0   IDE:eclipse Pydev 1. 由于Django自带auth, 故仅需编写登录登出的url和template即可 urls常见上篇 template代码如下仅供参考: login 1 {% extends "account_base.html" %} 2 3

python Django搭建博客

部署环境 系统CentOS Linux release 7.4.1708 python为Python 3.5 Django为Django-2.1.4 升级python2.7到python3.5 参考文章 下载python3.5 wget -S https://www.python.org/ftp/python/3.5.6/Python-3.5.6.tgz yum install openssl-devel yum install zlib yum install sqlite-devel(dja

django 搭建博客系统之创建博客的数据库模型

在我们之前已经创建好了虚拟环境,以及开始一个项目. 现在我们要添加一些功能性代码,django鼓励我们把自己编写的代码放入app中,每个app实现一个功能. 如今新建一个blog app 1,在虚拟环境下进入根目录,运行 python manage.py startapp blog.就建立了一个名为blog的应用,app. 2,在setting.py 中'告诉'django 存在这样的一个app. 好了 我们已经有了blog这个app,是要实现博客文章,博客的文章应该含有标题.正文.作者.发表时

Django搭建博客后台

转载自:http://sanwen8.cn/p/1cboypN.html 首先创建项目和blog应用: 在cmd命令行下,输入: django-admin.py startproject myblog 然后进入myblog目录,命令行下输入: python manage.py startapp blog 这是你的myblog下有两个目录,一个是myblog,目录下有文件:__init__.py,settings.py, urls.py,wsgi.py, 一个是blog,目录下有如下文件:__in

Django 编写博客网站的用户管理部分(采用自有的 django.contrib.auth) 1. 注册部分

项目工具:Python 2.7.11  Django 1.10.2  Bootstrap 3.3.0   IDE:eclipse Pydev 1. 首先确保settings中已有'django.contrib.auth' 例如: myproject下settings 1 INSTALLED_APPS = [ 2 'account', 3 'django.contrib.admin', 4 'django.contrib.auth', 5 'django.contrib.contenttypes'

OpenResty PHP WordPress 搭建博客网站(OpenResty与PHP在两台机器上)

一.了解openresty 一个全功能的 Web 应用服务器,它打包了标准的Nginx核心,很多的常用的第三方模块,以及它们的大多数依赖项.OpenResty 通过汇聚各种设计精良的 Nginx 模块,从而将 Nginx 有效的变成一个强大的 Web 应用服务器,这样, Web 开发人员可以使用 Lua 脚本语言调动 Nginx 支持的各种C以及Lua 模块,快速构造出足以胜任 10K+ 并发连接响应的超高性能Web 应用系统.OpenResty 的目标是让你的Web服务直接跑在 Nginx 服