Django-4.2博客开发教程:使用第三方库美化后台页面,丰富文章内容(七)

一、丰富文章内容

默认的输入是这样的

丰富编辑功能是这样的

我要做到这些,对于一个新人来说根本不可能实现的,现在有高人做出来并开源分享了出来,其中一个叫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',
]

默认的后台是这样的

美化后的是这样的

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值