장고:카테고리 만들기: 두 판 사이의 차이

학교의 모든 지식. SMwiki
둘러보기로 이동 검색으로 이동
(새 문서: {{장고}} ==개요== 글쓰기 기능을 구현하기 위해 정리한 문서. 기본적으로 포스팅 기능이지만, 모델명을 Post로 하기엔 전송방식인 post와 혼...)
 
편집 요약 없음
2번째 줄: 2번째 줄:


==개요==
==개요==
글쓰기 기능을 구현하기 위해 정리한 문서.
카테고리를 만들어보자.
 
기본적으로 포스팅 기능이지만, 모델명을 Post로 하기엔 전송방식인 post와 혼동이 오곤 해서 question으로 구현한다.


==url 작성==
==url 작성==
urls.py 안에 필요한 기능을 다 담아주어야 한다.
<br />


예컨대, 글을 쓴다면 만들기, 편집, 삭제기능을 만들어주어야 하기에 다음과 같이 기입한다.
==모델 작성==
[음.. 아무래도 many to many 형식으로 모델을 짜야 할 것 같은데.. 이건 카테고리가 상위에 있어.)


(뷰의 설정이나, import방식에 따라 뷰를 불러오는 방식이 달라질 수 있다.)<syntaxhighlight lang="python">
=== 카테고리 모델 작성 ===
path('question/create/', views.question_create, name='question_create'),
<syntaxhighlight lang="python">
path('question/modify/<int:question_id>/', views.question_modify, name='question_modify'),
from django.db import models
path('question/delete/<int:question_id>/', views.question_delete, name='question_delete'),
</syntaxhighlight><nowiki>#</nowiki>아직 함수를 짜주진 않았지만, 앞으로 만들 함수에 대해 연결해두자.


==모델 작성==
class Category(models.Model):
글에서 포함해야 할 것들이 있다. 작성자, 작성일자, 내용 등의 요소를 포함하여 모델을 작성한다.
    name=models.CharField(max_length=10, db_index=True)#db_index는 카테고리 정보가 저장되는 테이블에서 이 열을 인덱스 열로 설정한다는 옵션.
    category_number=models.숫자...필드! #카테고리 일련번호를 나타내기 위함.
    meta_description=models.TextField(blank=True)#구글 등 검색엔진에서 잘 검색되도록 정보를 제공하기 위한 것. SEO를 위해.
 
    def __str__(self):
        return self.subject
</syntaxhighlight><br />


/앱/models.py 안에 작성한다.<syntaxhighlight lang="python">
=== 분류될 모델 작성 ===
from django.contrib.auth.models import User
<syntaxhighlight lang="python">
from django.db import models
from django.db import models


class Question(models.Model):
class Category(models.Model):
     author = models.ForeignKey(User, on_delete=models.CASCADE, related_name='author_question')
     name=models.CharField(max_length=10, db_index=True)#db_index는 카테고리 정보가 저장되는 테이블에서 이 열을 인덱스 열로 설정한다는 옵션.
    subject = models.CharField(max_length=200)
     meta_description=models.TextField(blank=True)#구글 등 검색엔진에서 잘 검색되도록 정보를 제공하기 위한 것. SEO를 위해.
     content = models.TextField()
    create_date = models.DateTimeField()
    modify_date = models.DateTimeField(null=True, blank=True)


     def __str__(self):
     def __str__(self):
         return self.subject
         return self.subject
</syntaxhighlight><br />
</syntaxhighlight>
 
 
<br />


==뷰 작성==
==뷰 작성==
뷰가 많아지면 /앱/views/posting_view.py 따위의 이름으로 작성한다.
{| class="wikitable"
{| class="wikitable"
|+
!의도
!
!코드
!
|-
|-
|글작성
|카테고리 뷰
|<syntaxhighlight lang="python">
|#카테고리 번호가 주어지면 해당 카테고리에 대한 객체들만 보여주고,
from django.contrib.auth.decorators import login_required #로그인이 있어야 가능함
 
<nowiki>#</nowiki>카테고리 번호가 없다면, 전체 객체들을 보여준다.<syntaxhighlight lang="python">
from django.shortcuts import render, get_object_or_404, redirect
from django.shortcuts import render, get_object_or_404, redirect
from django.utils import timezone
from .models import Question, Category #모델을 불러온다.
 
from ..forms import QuestionForm #폼을 불러온다.
from ..models import Question #모델을 불러온다.
 


@login_required(login_url='common:login')
@login_required(login_url='common:login')
def question_create(request):
def question_in_category(request, category_number=None):
     if request.method == 'POST':#포스트로 요청이 들어온다면... 글을 올리는 기능.
     categories=Category.object.all()#카테고리 모델을 모두 부른다.
        form = QuestionForm(request.POST) #폼을 불러와 내용입력을 받는다.
    questions=Question.object.all() #카테고리 내부 요소를 모두 부른다. 필요에 따라 order를 사용하여 정렬하기도..
        if form.is_valid():
    if category_number: #카테고리 번호가 주어진다면..
            question = form.save(commit=False)
        current_category=get_object_or_404(Category, category_number=category_number)
            question.author = request.user  # 추가한 속성 author 적용
        questions=questions.object.filter(category=current_category) #다시 필터를 걸어 해당 카테고리 내부의 것들만 모은다.
            question.create_date = timezone.now()
    context = {'categories':categories,'current_category': current_category,
            question.save()
         'questions':questions}
            return redirect('pybo:index') #작성이 끝나면 목록화면으로 보낸다.
     return render(request, '.html', context)
    else:#포스트 요청이 아니라면.. form으로 넘겨 내용을 작성하게 한다.
         form = QuestionForm()
    context = {'form': form}
     return render(request, 'pybo/question_form.html', context)
</syntaxhighlight>
</syntaxhighlight>
|-
|-
|글수정
|
|
|
|-
|-
|
|
|from django.contrib import messages
|
|}
|}
<br />
<br />

2020년 10월 27일 (화) 21:50 판

장고! 웹 프레임워크! 틀:장고

  1. 장고:개요
  2. 장고:웹페이지설계
    1. 장고:앱
    2. 장고:url
    3. 장고:model
      1. 장고:DB
      2. 장고:모델 필드
      3. 장고:모델의 변경
    4. 장고:view
      1. 장고:클래스형 뷰, 제네릭 뷰
      2. 장고:view 각종 기능
    5. 장고:template
    6. 장고:static. 정적파일 사용하기
      1. 장고:CSS 사용하기
      2. 장고:JS 사용하기
      3. 장고:글꼴 사용
      4. 장고:부트스트랩
    7. 장고:media. 미디어 파일 사용하기
  3. 장고:관리자페이지
  4. 장고:settings.py
  5. 장고:기능구현
    1. 장고:회원관리
    2. 장고:유저
    3. 장고:커스텀 유저
    4. 장고:소셜로그인
    5. 장고:입력받기
    6. 장고:저장된 내용 활용하기
    7. 장고:변수 내보내기
    8. 장고:글쓰기
    9. 장고:페이징(페이지나누기)
    10. 장고:답변쓰기(댓글쓰기)
    11. 장고:추천,즐겨찾기
    12. 장고:새글(최신글) 나타내기
    13. 장고:썸머노트 설치
    14. 장고:네비게이션 바 만들기
    15. 장고:검색기능
    16. 장고:카테고리 만들기
    17. 장고:사진 올리기
    18. 장고:파일 업로드
    19. 장고:이메일app 만들기
    20. 장고:매직 그리드
  6. 장고:웹서비스
    1. 장고:Git
    2. 장고:리눅스에 올리기
    3. 장고:우분투에 올리기(nginx 사용)
    4. 장고:도커로 올리기
  7. 장고:팁

개요

카테고리를 만들어보자.

url 작성


모델 작성

[음.. 아무래도 many to many 형식으로 모델을 짜야 할 것 같은데.. 이건 카테고리가 상위에 있어.)

카테고리 모델 작성

from django.db import models

class Category(models.Model):
    name=models.CharField(max_length=10, db_index=True)#db_index는 카테고리 정보가 저장되는 테이블에서 이 열을 인덱스 열로 설정한다는 옵션.
    category_number=models.숫자...필드! #카테고리 일련번호를 나타내기 위함.
    meta_description=models.TextField(blank=True)#구글 등 검색엔진에서 잘 검색되도록 정보를 제공하기 위한 것. SEO를 위해.

    def __str__(self):
        return self.subject


분류될 모델 작성

from django.db import models

class Category(models.Model):
    name=models.CharField(max_length=10, db_index=True)#db_index는 카테고리 정보가 저장되는 테이블에서 이 열을 인덱스 열로 설정한다는 옵션.
    meta_description=models.TextField(blank=True)#구글 등 검색엔진에서 잘 검색되도록 정보를 제공하기 위한 것. SEO를 위해.

    def __str__(self):
        return self.subject



뷰 작성

의도 코드
카테고리 뷰 #카테고리 번호가 주어지면 해당 카테고리에 대한 객체들만 보여주고, #카테고리 번호가 없다면, 전체 객체들을 보여준다.
from django.shortcuts import render, get_object_or_404, redirect
from .models import Question, Category #모델을 불러온다.

@login_required(login_url='common:login')
def question_in_category(request, category_number=None):
    categories=Category.object.all()#카테고리 모델을 모두 부른다.
    questions=Question.object.all() #카테고리 내부 요소를 모두 부른다. 필요에 따라 order를 사용하여 정렬하기도..
    if category_number: #카테고리 번호가 주어진다면..
        current_category=get_object_or_404(Category, category_number=category_number)
        questions=questions.object.filter(category=current_category) #다시 필터를 걸어 해당 카테고리 내부의 것들만 모은다.
    context = {'categories':categories,'current_category': current_category,
        'questions':questions}
    return render(request, '.html', context)