記事のエントリ モデルがあり、抜粋と説明のフィールドがあります。ユーザーが画像を投稿したい場合は、デフォルトの標準ファイル ブラウザーを持つ個別の ImageField があります。
私は使用してみましたが、フラッシュアップロードユーティリティdjango-filebrowser
が必要であるという事実が好きではなく、django-grappelli
必ずしもフラッシュアップロードユーティリティが必要なわけでもありません-画像のアップロードを管理し、基本的にdjangoが提供するファイルブラウズを画像ピッキングに置き換えることができるツールを誰でも推奨できますか?ブラウザ?
将来的には、画像のサイズ変更を処理し、特定の記事タイプのデフォルトの画像サイズを指定したいと思うでしょう。
編集: adminfilesを試していますが、インストールに問題があります。私はそれをつかんで、Python パスに追加し、INSTALLED_APPS に追加し、データベースを作成し、画像をアップロードしました。指示に従ってモデルを変更し、指定adminfiles_fields
して登録しましたが、管理者には適用されませんadmin.py
。記事は次のとおりです。
from django.contrib import admin
from django import forms
from articles.models import Category, Entry
from tinymce.widgets import TinyMCE
from adminfiles.admin import FilePickerAdmin
class EntryForm( forms.ModelForm ):
class Media:
js = ['/media/tinymce/tiny_mce.js', '/media/tinymce/load.js']#, '/media/admin/filebrowser/js/TinyMCEAdmin.js']
class Meta:
model = Entry
class CategoryAdmin(admin.ModelAdmin):
prepopulated_fields = { 'slug': ['title'] }
class EntryAdmin( FilePickerAdmin ):
adminfiles_fields = ('excerpt',)
prepopulated_fields = { 'slug': ['title'] }
form = EntryForm
admin.site.register( Category, CategoryAdmin )
admin.site.register( Entry, EntryAdmin )
これが私のエントリーモデルです:
class Entry( models.Model ):
LIVE_STATUS = 1
DRAFT_STATUS = 2
HIDDEN_STATUS = 3
STATUS_CHOICES = (
( LIVE_STATUS, 'Live' ),
( DRAFT_STATUS, 'Draft' ),
( HIDDEN_STATUS, 'Hidden' ),
)
status = models.IntegerField( choices=STATUS_CHOICES, default=LIVE_STATUS )
tags = TagField()
categories = models.ManyToManyField( Category )
title = models.CharField( max_length=250 )
excerpt = models.TextField( blank=True )
excerpt_html = models.TextField(editable=False, blank=True)
body_html = models.TextField( editable=False, blank=True )
article_image = models.ImageField(blank=True, upload_to='upload')
body = models.TextField()
enable_comments = models.BooleanField(default=True)
pub_date = models.DateTimeField(default=datetime.datetime.now)
slug = models.SlugField(unique_for_date='pub_date')
author = models.ForeignKey(User)
featured = models.BooleanField(default=False)
def save( self, force_insert=False, force_update= False):
self.body_html = markdown(self.body)
if self.excerpt:
self.excerpt_html = markdown( self.excerpt )
super( Entry, self ).save( force_insert, force_update )
class Meta:
ordering = ['-pub_date']
verbose_name_plural = "Entries"
def __unicode__(self):
return self.title
編集#2:メディアファイルをメディアパスに移動したことを明確にするために、それらは実際に画像領域をレンダリングしています。アップロードできます。<<<image>>>
タグは編集可能なMarkItUp w / Markdown領域に挿入されますが、 MarkItUp プレビュー - おそらく、|upload_tags
そのプレビューに を適用する必要があるだけです。記事を投稿するテンプレートにも追加してみます。