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地址看了一下.
- Get the code: pip install django-pagedown
- Add pagedown to your INSTALLED_APPS
- 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里面就可以直接使用了.
Django搭建博客网站(四)的更多相关文章
- Django搭建博客网站(三)
Django搭建博客网站(三) 第三篇主要记录view层的逻辑和template. Django搭建博客网站(一) Django搭建博客网站(二) 结构 网站结构决定我要实现什么view. 我主要要用 ...
- Django搭建博客网站(二)
Django搭建自己的博客网站(二) 这里主要讲构建系统数据库Model. Django搭建博客网站(一) model 目前就只提供一个文章model和一个文章分类标签model,在post/mode ...
- Django搭建博客网站(一)
Django搭建自己的博客网站(一) 简介 这个系列主要是通过使用Django这个python web框架实现一个简单的个人博客网站.对Django有疑问可以上Django官网查文档. 功能 后台管理 ...
- 使用django搭建博客并部署
2017/8/31 18:27:59 为了以后参考的方便,在这里总结一下django搭建博客网站的主要步骤.以下大部分的内容,参考自Django中文文档 - 看云. 需要强调的是,这里使用的djang ...
- 手把手教从零开始在GitHub上使用Hexo搭建博客教程(四)-使用Travis自动部署Hexo(2)
前言 前面一篇文章介绍了Travis自动部署Hexo的常规使用教程,也是个人比较推荐的方法. 前文最后也提到了在Windows系统中可能会有一些小问题,为了在Windows系统中也可以实现使用Trav ...
- Django搭建博客记(一)
这里记录一些 Django 搭建博客遇到的一些问题 参考书籍为 Django by Example, 这里记录与书籍内容不包含的内容. 搭建环境: 阿里云 ECS + CentOS7 一开始搭建的时候 ...
- Hexo系列(一) 搭建博客网站
写在前面的话:本系列文章主要参考 Hexo官方说明文档,同时结合自己在使用过程中的一些心得体会,撷取下来,和大家分享分享.好,下面闲话不多说,马上开始我们的 Hexo 之旅吧 温馨提醒:博主使用的操作 ...
- Django 系列博客(四)
Django 系列博客(四) 前言 本篇博客介绍 django 如何和数据库进行交互并且通过 model 进行数据的增删查改 ORM简介 ORM全称是:Object Relational Mappin ...
- 部署项目到服务器 & 搭建博客网站
搭建博客网站 作为名程序员,或者是网络编程爱好者,拥有一个自己的博客网站再好不过,本篇文章手把手教你部署自己的网站
随机推荐
- mysql 恢复数据
前提:保存了需要恢复数据库的文件 .frm 和 .ibd 文件 条件:InnoDB 类型的 恢复表结构1.新建一个数据库--新建一个表,表名和列数和需要恢复数据库相同2.停止mysql服务器 serv ...
- java实现最小生成树的prim算法和kruskal算法
在边赋权图中,权值总和最小的生成树称为最小生成树.构造最小生成树有两种算法,分别是prim算法和kruskal算法.在边赋权图中,如下图所示: 在上述赋权图中,可以看到图的顶点编号和顶点之间邻接边的权 ...
- Java数据持久层框架 MyBatis之API学习十(Logging详解)
对于MyBatis的学习而言,最好去MyBatis的官方文档:http://www.mybatis.org/mybatis-3/zh/index.html 对于语言的学习而言,马上上手去编程,多多练习 ...
- [知了堂学习笔记]_css3特效第二篇--行走的线条&&置顶导航栏
一.行走的线条. 效果图(加载可能会慢一点儿,请稍等...): html代码: <div class="movingLines"> <img src=" ...
- js设置定时器
1,利用settimeout,语法: setTimeout(/*执行代码*/, /*毫秒*/);每过多少毫秒执行一次代码 <button id="sms">发送验证码& ...
- linkin大话面向对象--包装类
Java提倡的万物皆对象,但是数据类型的划分出现了基本数据类型和引用数据类型,那么我们怎么能把基本数据类型称为对象呢? 基本数据类型 包装类 byte Byte short Short int Int ...
- android之间传递list
Intent intent = new Intent(getActivity(), Activity_Character.class); intent.putExtra("mlTrait&q ...
- JDBC (三)
1 数据库连接池的原理 应用程序直接获取Connection的缺点: 缺点:用户每次请求都需要向数据库获取连接,而数据库创建连接通常需要消耗相对较大的资源,创建的时间较长.如果一个网站一天访问量是10 ...
- 【转】Linux Oracle服务启动&停止脚本与开机自启动
在CentOS 6.3下安装完Oracle 10g R2,重开机之后,你会发现Oracle没有自行启动,这是正常的,因为在Linux下安装Oracle的确不会自行启动,必须要自行设置相关参数,首先先介 ...
- Elasticsearch 全教程--入门
1.1 初识 Elasticsearch 是一个建立在全文搜索引擎 Apache Lucene(TM) 基础上的搜索引擎,可以说 Lucene 是当今最先进,最高效的全功能开源搜索引擎框架. 但是 L ...