30. (app2) 커스텀 From 직접 만들기(detail.html수정)
모델을 이용해 만드는 방법은 디자인이 한정되어 있는데 이것은 사용자 마음대로 디자인을 구성할 수 있다.
1. detail.html수정
- 아래의 코드로 수정.
- question 객체는 views의 detail메소드로부터 전달받은 것.
- error_message 가 있다면 에러메시지 출력.
- form의 action에는 전달할 url이 들어간다.
- csrf_token은 보안때문에 항상 넣어줘야 한다.(CSRF : 사용자의 의지와는 무관하게 공격자가 의도한 행위CRUD를 특정 웹사이트에 요청하게 하는 공격)
- input은 라디오버튼, 라벨은 그 옆의 텍스트를 생성한다.
- input의 id에서 choice는 그냥 텍스트이고 forloop.counter를 해주면 1부터 증가하는 숫자가 들어가게 된다. value에서 choice.id는 객체의 primary key 값임.
- label의 for는 input의 id와 연결됨을 의미.
- 두번째 코드는 페이지에 접속 후 코드를 보면 보여지는 코드.
- 아직까지는 투표 버튼을 눌러도 투표수가 증가하진 않는다.
<h2>{{ question.question_text }}</h2>
{% if error_message %}
<p><strong>{{ error_message }}</strong></p>
{% endif %}
<form action="{% url 'polls:vote' question.id%}" method="POST">
{% csrf_token %}
{% for choice in question.choice_set.all %}
<input type="radio" name="choice" id="choice{{ forloop.counter }}" value="{{ choice.id}}"/>
<label for="choice{{ forloop.counter }}"> {{choice.choice_text}} <label/><br>
{% endfor %}
<input type="submit" value="투표"/>
</form>
<h2>짜장?짬뽕?</h2>
<form action="/polls/5/vote/" method="POST">
<input type='hidden' name='csrfmiddlewaretoken' value='xbZ6P6EvrM0SVs7YrNbSsKbozunoacVOBE3S8aA3Pbqh5ac1UIuvQXQcmzNA4B8o' />
<input type="radio" name="choice" id="choice1" value="9"/>
<label for="choice1"> 짜장 <label/><br>
<input type="radio" name="choice" id="choice2" value="10"/>
<label for="choice2"> 짬뽕 <label/><br>
<input type="submit" value="투표"/>
</form>