장고:관리자페이지
편집하기
Sam
(
토론
|
기여
)
님의 2020년 11월 8일 (일) 21:41 판
(
→관리자 화면 커스터마이징
)
(
차이
)
← 이전 판
|
최신판
(
차이
) |
다음 판 →
(
차이
)
둘러보기로 이동
검색으로 이동
경고: 이 문서의 오래된 판을 편집하고 있습니다.
이것을 게시하면, 이 판 이후로 바뀐 모든 편집이 사라집니다.
경고:
로그인하지 않았습니다. 편집을 하면 IP 주소가 공개되게 됩니다.
로그인
하거나
계정을 생성하면
편집자가 사용자 이름으로 기록되고, 다른 장점도 있습니다.
스팸 방지 검사입니다. 이것을 입력하지
마세요
!
{{장고}} ==개요== 장고에선 기본적인 관리자 기능에 대해 구현해 두었다. {| class="wikitable" |+ !과정 !설명 |- |관리자등록 |python manage.py createsuperuser 이후 안내되는 메시지대로 작성한다. |- |관리자페이지 |도메인주소/admin에 들어가면 관리자페이지가 나온다. |- |모델등록 |모델등록은 앱별로 한다. /앱이름/admin.py 안에서 모델을 불러오고, 등록한다.<syntaxhighlight lang="python"> from django.contrib import admin#처음에 있던 거. 그냥 두자. from .models import 모델명 #모델을 불러오고 admin.site.register(모델명) #모델을 등록한다. </syntaxhighlight>DB를 안만들었다면 python manage.py makemigrations 과 python manage.py migrate를 실행하자. 이렇게 등록하고 나면 관리자페이지에서 앱별로 모델을 볼 수 있고, 데이터의 추가, 수정, 삭제가 가능하다. |- |모델제목으로 보기 |이렇게 등록하고 나면 모델의 제목이 아니라 이상한 텍스트로 보이는데, 모델의 제목으로 보기 위해선 모델클래스에 함수를 추가해주어야 한다. models.py에서 편집해준다.<syntaxhighlight lang="python"> class Question(models.Model):#세부내용은 필요에 따라.. .... def __str__(self):#관리자페이지에 나타낼 객체 이름. return self.subject#이 객체의 subject를 관리자화면에서 이름으로 쓰겠다는 의미. </syntaxhighlight> |} ===디자인 변경=== 관리자페이지의 디자인은 장고의 <code>django\contrib\admin\templates\admin\abse_site.html</code> 에 있다. 이를 복사하여 <code>templates/admin/</code> 경로에 붙여넣으면 이를 기초 html로 인식한다. =기능= ==관리자 화면 커스터마이징== 기본적으로 클래스를 새로이 지정해준 후 등록하는 방식을 거친다.<syntaxhighlight lang="python"> from django.contrib import admin from .models import Question #모델을 불러오고 class QuestionAdmin(admin.ModelAdmin):#관리자기능을 위한 클래스 필요한 내용. admin.site.register(Question,QuestionAdmin) #QuestionAdmin의 등록을 추가한다. </syntaxhighlight> === 객체 배치 === {| class="wikitable" |+ !의도 !설명 !코드(QuestionAdmin 안에 추가한다.) |- |나타나는 필드 순서 변경하기 |앱이름/admin.py 파일의 클래스에서 필드 순서 변경 |<syntaxhighlight lang="python"> fields=['필드명', '필드명2',...]#필드명의 순서에 따라 정렬 </syntaxhighlight> |- |디스플레이항목조정(필드 순서와 다를 게 무엇일까;;) |관리자화면 목록에 나오는 항목들을 조정하고 싶을 때가 있다. 다음과 같이 list_display 변수를 지정하는 것으로 가능하다. |<syntaxhighlight lang="python"> list_display=('모델의 하위속성1', '모델의 하위속성2',...) </syntaxhighlight> |- |필터 |해당 속성에 필터를 걸면 모델의 필드에 맞춰 자동으로 필터를 생성한다.(날짜의 경우, 오늘, 최근7일 등) |<syntaxhighlight lang="python"> list_filter=['필터를 걸 속성'] </syntaxhighlight> |- |모델검색 |여러 필드를 기입해 검색의 범위를 지정할 수 있다. |<syntaxhighlight lang="python"> search_fields = ['subject'] #검색할 필드를 넣어준다. </syntaxhighlight> |- | | | |} ===수정화면 조정=== 디테일을 볼 수 있는 내용. 수정화면에서 모델의 속성을 그룹화 하여 수정화면을 편집할 수 있다.<syntaxhighlight lang="python"> from django.contrib import admin from .models import Question #모델을 불러오고 class QuestionAdmin(admin.ModelAdmin):#관리자기능을 위한 클래스 fieldsets=[ ('나타낼그룹명', {'fields':['해당항목']}), (None, {'fields':['해당항목1', 해당항목2]}), ] admin.site.register(Question,QuestionAdmin) #QuestionAdmin의 등록을 추가한다. </syntaxhighlight> ===하위객체와의 관계=== {| class="wikitable" !의도 !설명 !코드 |- |하위객체 한 화면에서 보기 |연결된 하위객체를 한 화면에서 보고 조작할 수 있다면 관리가 수월해진다. |<syntaxhighlight lang="python"> from django.contrib import admin from .models import Question, Answer #모델을 불러오고 class AnsewerInline(admin.StackedInline): model=Answer extra=3#기존에 있던 외에 추가할 수 있는 칸. 몇 개를 만들 것인가? class QuestionAdmin(admin.ModelAdmin): inlines=[AnsewerInline]#위에서 작성한 클래스를 넣어준다. admin.site.register(Question,QuestionAdmin) #QuestionAdmin의 등록을 추가한다. </syntaxhighlight> |- |표로 간결하게 보기 |하지만, 위처럼 쓰면 관리자페이지가 너무 길어져 불편하기도 하다. 이럴 땐 객체들을 테이블 형태로 만들어주어야 하는데, 다음과 같이 부모클래스만 바꾸어주면 된다. |<syntaxhighlight lang="python"> class AnsewerInline(admin.TabularInline): model=Answer extra=3 </syntaxhighlight> |} <br />
요약:
학교의 모든 지식. SMwiki에서의 모든 기여는 크리에이티브 커먼즈 저작자표시-비영리-동일조건변경허락 라이선스로 배포된다는 점을 유의해 주세요(자세한 내용에 대해서는
학교의 모든 지식. SMwiki:저작권
문서를 읽어주세요). 만약 여기에 동의하지 않는다면 문서를 저장하지 말아 주세요.
또한, 직접 작성했거나 퍼블릭 도메인과 같은 자유 문서에서 가져왔다는 것을 보증해야 합니다.
저작권이 있는 내용을 허가 없이 저장하지 마세요!
취소
편집 도움말
(새 창에서 열림)
이 문서에서 사용한 틀:
틀:장고
(
원본 보기
) (보호됨)
둘러보기 메뉴
개인 도구
로그인하지 않음
토론
기여
로그인
이름공간
문서
토론
한국어
보기
읽기
편집
원본 편집
역사 보기
더 보기
검색
둘러보기
대문
최근 바뀜
임의의 문서로
미디어위키 도움말
도구
여기를 가리키는 문서
가리키는 글의 최근 바뀜
특수 문서 목록
문서 정보