一、丰富文章内容
默认的输入是这样的
丰富编辑功能是这样的
我要做到这些,对于一个新人来说根本不可能实现的,现在有高人做出来并开源分享了出来,其中一个叫DjangoUeditor,当然还有很多大家可以自行研究。
这个库在github虽然开源但作者没有维护,只停留到django1.x的版本兼容,大家可以pip install DjangoUeditor 自行体验。
我这里有个基于别人的进行了维护版,https://github.com/lihongbin668/Django4Ueditor
操作步骤:
1、从上面的链接下载库,code》download zip。下载到本地任意目录
2、安装依赖 pip install six
然后到 .\Lib\site-packages 这个目录下,会发现有一个 six.py 的文件,直接 copy 到 venv\Lib\site-packages\django\utils
3、解压下载的库并安装
python setup.py install
4、修改项目的配置
settings.py里注册APP,在INSTALLED_APPS里添加'DjangoUeditor'
INSTALLED_APPS = [ # 'blog.apps.BlogConfig', #注册APP应用 'blog', #第三方应用 'DjangoUeditor', #django自带 'django.contrib.admin', 'django.contrib.auth', 'django.contrib.contenttypes', 'django.contrib.sessions', 'django.contrib.messages', 'django.contrib.staticfiles', ]
myblog/urls.py里添加url
from django.contrib import admin from django.urls import path, include from DjangoUeditor import urls urlpatterns = [ path('admin/', admin.site.urls), path('ueditor/', include('DjangoUeditor.urls')), #添加DjangoUeditor的URL ]
修改blog/models.py里需要使用富文本编辑器渲染的字段
class Article(models.Model): ... # content = models.TextField() #原来的内容 content = UEditorField('内容', width=800, height=500, toolbars="full", imagePath="upimg/", filePath="upfile/", upload_settings={"imageMaxSize": 1204000}, settings={}, command=None, blank=True ) ...
图片无法正常显示解决:
myblog/urls.py文件,在里面输入如下代码:
from django.contrib import admin from django.urls import path, include, re_path from django.views.static import serve from django.conf import settings from DjangoUeditor import urls urlpatterns = [ path('admin/', admin.site.urls), path('ueditor/', include('DjangoUeditor.urls')), #添加DjangoUeditor的URL re_path('^media/(?P<path>.*)$', serve, {'document_root': settings.MEDIA_ROOT}), ]
二、美化管理后台
美化管理后台需要使用到另一个库django-simpleui
pip3 install django-simpleui
1秒变后台,在myblogs/settings.py 第3方应用添加库就可以了 'simpleui',
INSTALLED_APPS = [ # 'blog.apps.BlogConfig', #注册APP应用 'blog', #第三方应用 'DjangoUeditor', 'simpleui', #django自带 'django.contrib.admin', 'django.contrib.auth', 'django.contrib.contenttypes', 'django.contrib.sessions', 'django.contrib.messages', 'django.contrib.staticfiles', ]
默认的后台是这样的
美化后的是这样的