장고:글쓰기: 두 판 사이의 차이
(새 문서: {{장고}} == 개요 == 글쓰기 기능을 구현하기 위해 정리한 문서. 기본적으로 포스팅 기능이지만, 모델명을 Post로 하기엔 전송방식인 post와...) |
잔글 (→뷰 작성) |
||
1번째 줄: | 1번째 줄: | ||
{{장고}} | {{장고}} | ||
== 개요 == | ==개요== | ||
글쓰기 기능을 구현하기 위해 정리한 문서. | 글쓰기 기능을 구현하기 위해 정리한 문서. | ||
기본적으로 포스팅 기능이지만, 모델명을 Post로 하기엔 전송방식인 post와 혼동이 오곤 해서 question으로 구현한다. | 기본적으로 포스팅 기능이지만, 모델명을 Post로 하기엔 전송방식인 post와 혼동이 오곤 해서 question으로 구현한다. | ||
== url 작성 == | ==url 작성== | ||
urls.py 안에 필요한 기능을 다 담아주어야 한다. | urls.py 안에 필요한 기능을 다 담아주어야 한다. | ||
19번째 줄: | 19번째 줄: | ||
<nowiki>#</nowiki>아직 함수를 짜주진 않았지만, 앞으로 만들 함수에 대해 연결해두자. | <nowiki>#</nowiki>아직 함수를 짜주진 않았지만, 앞으로 만들 함수에 대해 연결해두자. | ||
== 모델 작성 == | ==모델 작성== | ||
글에서 포함해야 할 것들이 있다. 작성자, 작성일자, 내용 등의 요소를 포함하여 모델을 작성한다. | 글에서 포함해야 할 것들이 있다. 작성자, 작성일자, 내용 등의 요소를 포함하여 모델을 작성한다. | ||
37번째 줄: | 37번째 줄: | ||
</syntaxhighlight> | </syntaxhighlight> | ||
=== 설명 === | ===설명=== | ||
{| class="wikitable" | {| class="wikitable" | ||
!내용 | !내용 | ||
58번째 줄: | 58번째 줄: | ||
|} | |} | ||
=== 모든 필드에서 쓰는 옵션 === | ===모든 필드에서 쓰는 옵션=== | ||
null=True는 빈 값도 인정한다는 의미이다. 기본적으로 False. | null=True는 빈 값도 인정한다는 의미이다. 기본적으로 False. | ||
=== 자주 사용하는 필드 === | ===자주 사용하는 필드=== | ||
{| class="wikitable" | {| class="wikitable" | ||
!내용 | !내용 | ||
91번째 줄: | 91번째 줄: | ||
이외 내용은 장고 공식 메뉴얼의 필드 레퍼런스를 참조. https://docs.djangoproject.com/en/3.1/ref/models/fields/#db-index | 이외 내용은 장고 공식 메뉴얼의 필드 레퍼런스를 참조. https://docs.djangoproject.com/en/3.1/ref/models/fields/#db-index | ||
== 뷰 작성 == | ==뷰 작성== | ||
/앱/views/question_view.py 따위의 이름으로 작성한다. | /앱/views/question_view.py 따위의 이름으로 작성한다. | ||
{| class="wikitable" | {| class="wikitable" | ||
110번째 줄: | 110번째 줄: | ||
@login_required(login_url='common:login') | @login_required(login_url='common:login') | ||
def question_create(request): | def question_create(request): | ||
if request.method == 'POST':#포스트로 요청이 들어온다면... | if request.method == 'POST':#포스트로 요청이 들어온다면... 글을 올리는 기능. | ||
form = QuestionForm(request.POST) #폼을 불러와 내용입력을 받는다. | form = QuestionForm(request.POST) #폼을 불러와 내용입력을 받는다. | ||
if form.is_valid(): | if form.is_valid(): | ||
118번째 줄: | 118번째 줄: | ||
question.save() | question.save() | ||
return redirect('pybo:index') #작성이 끝나면 목록화면으로 보낸다. | return redirect('pybo:index') #작성이 끝나면 목록화면으로 보낸다. | ||
else: | else:#포스트 요청이 아니라면.. form으로 넘겨 내용을 작성하게 한다. | ||
form = QuestionForm() | form = QuestionForm() | ||
context = {'form': form} | context = {'form': form} |
2020년 9월 18일 (금) 16:03 판
장고! 웹 프레임워크! 틀:장고
개요
글쓰기 기능을 구현하기 위해 정리한 문서.
기본적으로 포스팅 기능이지만, 모델명을 Post로 하기엔 전송방식인 post와 혼동이 오곤 해서 question으로 구현한다.
url 작성
urls.py 안에 필요한 기능을 다 담아주어야 한다.
예컨대, 글을 쓴다면 만들기, 편집, 삭제기능을 만들어주어야 하기에 다음과 같이 기입한다.
path('question/create/', question_views.question_create, name='question_create'),
path('question/modify/<int:question_id>/', question_views.question_modify, name='question_modify'),
path('question/delete/<int:question_id>/', question_views.question_delete, name='question_delete'),
#아직 함수를 짜주진 않았지만, 앞으로 만들 함수에 대해 연결해두자.
모델 작성
글에서 포함해야 할 것들이 있다. 작성자, 작성일자, 내용 등의 요소를 포함하여 모델을 작성한다.
/앱/models.py 안에 작성한다.
from django.contrib.auth.models import User
from django.db import models
class Question(models.Model):
author = models.ForeignKey(User, on_delete=models.CASCADE, related_name='author_question')
subject = models.CharField(max_length=200)
content = models.TextField()
create_date = models.DateTimeField()
modify_date = models.DateTimeField(null=True, blank=True)
def __str__(self):
return self.subject
설명
내용 | 설명 |
---|---|
author = models.ForeignKey | author속성을 외부의 객체를 불러온다는 의미. |
(User, on_delete=models.CASCADE, related_name='author_question') | |
subject = models.CharField(max_length=200) | 제목은 200자까지 문자열로 받는다. |
create_date = models.DateTimeField() | 시간을 담는 공간이다. |
modify_date = models.DateTimeField(null=True, blank=True) | 수정시간을 담는다. |
모든 필드에서 쓰는 옵션
null=True는 빈 값도 인정한다는 의미이다. 기본적으로 False.
자주 사용하는 필드
내용 | 설명 | 옵션 | ||||
---|---|---|---|---|---|---|
models.CharField | 텍스트 필드.
(글자제한을 위해) |
| ||||
models.TextField | 텍스트 필드.
(글자제한 없음) |
|||||
models.DateTimeField | 시간담기 |
이외 내용은 장고 공식 메뉴얼의 필드 레퍼런스를 참조. https://docs.djangoproject.com/en/3.1/ref/models/fields/#db-index
뷰 작성
/앱/views/question_view.py 따위의 이름으로 작성한다.
글작성 | from django.contrib.auth.decorators import login_required #로그인이 있어야 가능함
from django.shortcuts import render, get_object_or_404, redirect
from django.utils import timezone
from ..forms import QuestionForm #폼을 불러온다.
from ..models import Question #모델을 불러온다.
@login_required(login_url='common:login')
def question_create(request):
if request.method == 'POST':#포스트로 요청이 들어온다면... 글을 올리는 기능.
form = QuestionForm(request.POST) #폼을 불러와 내용입력을 받는다.
if form.is_valid():
question = form.save(commit=False)
question.author = request.user # 추가한 속성 author 적용
question.create_date = timezone.now()
question.save()
return redirect('pybo:index') #작성이 끝나면 목록화면으로 보낸다.
else:#포스트 요청이 아니라면.. form으로 넘겨 내용을 작성하게 한다.
form = QuestionForm()
context = {'form': form}
return render(request, 'pybo/question_form.html', context)
|
글수정 | |
from django.contrib import messages |