前言
django是一个容易快速上手的web框架,用它来创建内容驱动型的网站(比如独立博客)十分方便。遗憾的是,django并没有提供官方的富文本编辑器,而后者恰好是内容型网站后台管理中不可或缺的控件。ckeditor是一款基于javascript,使用非常广泛的开源网页编辑器。它可以和多种编程语言相结合,python当然也不例外。本文就来介绍一下如何在基于django博客系统如何完美地用上ckeditor。
使用方法
1、安装
pip install django-ckeditor
2、将‘ckeditor'settings.py中的installed_apps
3、由于djang-ckeditor在ckeditor-init.js文件中使用了jquery,所以要在settings.py中设置ckeditor_jquery_url来指定jquery库的路径,例如:
ckeditor_jquery_url ='https://apps.bdimg.com/libs/jquery/2.1.4/jquery.min.js'
4、设定static_root,执行python manage.py collectstatic,将ckeditor需要的媒体资源拷入static_root指定的路径中。
static_root = os.path.join(base_dir,'static/')
5、
from django.db import models from ckeditor.fields import richtextfield class blog(models.model): title = models.charfield(max_length=50,verbose_name="标题") content = richtextfield(blank=true,null=true,verbose_name="内容") def __unicode__(self): return self.name
效果:
文件上传
1、在settings.py中的installed_apps中添加ckeditor_uploader
2、ckeditor使用django的存储api,默认使用django的文件存储,会用到media_root和media_url,需要在settings.py中定义,此外还可以指定ckeditor_upload_path,它位于media_root下:
media_url = '/media/' media_root = os.path.join(base_dir,'media/') ckeditor_upload_path = 'uploads/'
3、在项目的urls.py中添加ckeditor的url映射
url(r'^ckeditor/', include('ckeditor_uploader.urls')),
如果不加,可能会出现以下错误:
4、(可选项) 在settings.py中加入ckeditor_image_backend ,使能thumbnails,例如:
ckeditor_image_backend = 'pil'
from ckeditor_uploader.fields import richtextuploadingfield class post(models.model): content = richtextuploadingfield()
总结
以上就是django教你如何轻松使用富文本编辑器ckeditor的详细内容。
