0
ページングを作成しようとするので、JSのいくつかの行を使用してデータを送信し、正しくキャッチして(コンソールで印刷することもできます)変更しないでください。Djangoは同じテンプレートでレンダリングする
CONSOLE.LOG:
[15/Mar/2017 14:30:09] "POST /index/ HTTP/1.1" 200 15320
[POST] 2
[15/Mar/2017 14:30:10] "POST /index/ HTTP/1.1" 200 9003
[POST] 3
[15/Mar/2017 14:30:10] "POST /index/ HTTP/1.1" 200 9003
[POST] 4
[15/Mar/2017 14:30:16] "POST /index/ HTTP/1.1" 200 9003
[POST] 1
Template.html:
<p> THIS IS THE PAGE {{ page }} </p>
<div class="col-xs-12 center">
<ul class="pagination" >
<li><a href="#" value={{ page|add:"-1" }}>«</a></li>
<li><a href="#" value=0>1</a></li>
<li><a href="#" value=1>2</a></li>
<li><a href="#" value=2>3</a></li>
<li><a href="#" value=3>4</a></li>
<li><a href="#" value=4>5</a></li>
<li><a href="#" value={{ page|add:"1" }}>»</a></li>
</ul>
</div>
<script language="javascript">
$('ul.pagination li a').on('click', function(e){
e.preventDefault();
$.ajax({
url: '/index/',
type: 'POST',
headers: {'X-CSRFToken': '{{ csrf_token }}'},
data: {'page': $(this).attr('value')},
contentType: 'application/x-www-form-urlencoded; charset=utf-8',
processData: true,
});
})
</script>
Views.py:
def index(request):
print("[POST]",request.POST.get('page'))
page = int(request.POST.get('page', 0))
return render(request, "site/index.html",
{'page': page})
だから私は、私は考えている場合on /index/
私は新しい変数でインデックスの新しいレンダリングを行うことはできません(そしてこの変数で新しいレンダリングもできます)?
私はそれを行うことができますか?
EDIT:コンソールログを追加すると、私はpage
の値をJSで捕まえることができます。
Djangoに組み込まれた 'Paginator'クラスを試してもよろしいですか? JavaScriptコードは必要ありませんが、ページを変更するたびにページが更新されます。 https://docs.djangoproject.com/en/1.10/topics/pagination/ – themanatuf
これは良い方法ですが、私は実際に同じページを書き換えたり上書きしようとしています。 – Buky