Home  >  Article  >  Backend Development  >  Django teaches you how to master the rich text editor CKEditor

Django teaches you how to master the rich text editor CKEditor

Y2J
Y2JOriginal
2017-04-24 11:51:501734browse

Recently, I need to use rich text in django adminEditor. Since I prefer CKEditor rich text editor, I have this article. The following article mainly introduces it to you. Friends in need can refer to how to easily use the rich text editor CKEditor in Django.

Preface

Django is an easy and quick web framework, use it to create content driven type websites (such as independent blogs) are very convenient. Unfortunately, Django does not provide an official rich text editor, which happens to be an indispensable control in the backend management of content-based websites. ckeditor is a widely used open source web page editor based on javascript. It can be combined with a variety of programming languages, and python is of course no exception. This article will introduce how to use ckeditor perfectly in a Django-based blog system.

Usage

1. Install

pip install django-ckeditor

2. Change INSTALLED_APPS## in 'ckeditor'settings.py

#3. Since djang-ckeditor uses JQuery in the ckeditor-init.js file, you need to set CKEDITOR_JQUERY_URL in settings.py to specify the path of the JQuery library, for example:

CKEDITOR_JQUERY_URL ='https://apps.bdimg.com/libs/jquery/2.1.4/jquery.min.js'

4. Set Set STATIC_ROOT, execute

python manage.py collectstatic, and copy the media resources required by CKEditor into the path specified by STATIC_ROOT.

STATIC_ROOT = os.path.join(BASE_DIR,'static/')

Django teaches you how to master the rich text editor CKEditor

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

Effect:

Django teaches you how to master the rich text editor CKEditor

##File upload 1. Add ckeditor_uploader in INSTALLED_APPS in settings.py

2. CKEditor uses Django’s storage

API

, and uses Django’s files by default For storage, MEDIA_ROOT and MEDIA_URL will be used, which need to be defined in settings.py. In addition, CKEDITOR_UPLOAD_PATH can also be specified, which is located under MEDIA_ROOT:

MEDIA_URL = '/media/'
MEDIA_ROOT = os.path.join(BASE_DIR,'media/')
CKEDITOR_UPLOAD_PATH = 'uploads/'
3. Add the URL mapping of CKEditor in the project's urls.py

url(r'^ckeditor/', include('ckeditor_uploader.urls')),

If not added, the following error may occur:

Django teaches you how to master the rich text editor CKEditor4. (Optional) Add CKEDITOR_IMAGE_BACK

END## in settings.py #, enable thumbnails, for example:

CKEDITOR_IMAGE_BACKEND = 'PIL'
from ckeditor_uploader.fields import RichTextUploadingField
class Post(models.Model):
 content = RichTextUploadingField()

Summary

The above is the detailed content of Django teaches you how to master the rich text editor CKEditor. For more information, please follow other related articles on the PHP Chinese website!

Statement:
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn