Django AJAX удалить объект в deleteView - PullRequest
0 голосов
/ 29 марта 2020

Добрый день.

Я пытаюсь понять, как использовать ajax, удаляя объект.

Основная проблема, я не понимаю, как передать аргумент slug в URL в AJAX звоните.

path('posts/<slug:slug>/delete/', DeletePost.as_view(), name='delete_post')

class DeletePost(CsrfExemptMixin, DeleteView):
    queryset = Post.objects.all()

    def get_object(self, queryset=None):
        obj = super(DeletePost, self).get_object()
        profile = Profile.objects.get(user_id__exact=self.request.user.id)
        if obj.profile_id != profile.id:
            raise Http404
        return obj

    def delete(self, request, *args, **kwargs):
        self.get_object().delete()
        payload = {'delete': 'ok'}
        return JsonResponse(payload)

Что я также хочу понять, правильная ли функциональность? Я тестировал без json и get_object возвращает правильный объект.

  {% for post in user_posts %}
                            <tr id="post_table">
                                <th scope="row">
                                    <input type="checkbox" aria-label="Checkbox" style="display: none">
                                </th>
                                <td class="tm-product-name"><a href="{% url 'post:edit_post' post.slug %}">{{ post.title }}</a></td>
                                    <td class="text-center">145</td>
                                    <td class="text-center">{{ post.total_likes }}</td>
                                    <td>{{ post.created_at }}</td>
                                    <td><button class="delete-icon" onclick='deletePost({{ post.slug }})'>btn</button></td>
                                    {#<td><i  class="fas fa-trash-alt tm-trash-icon delete-icon" id="{{ post.id }}"></i></td>#}
                                    <td>
                                    {#<form method="post" action="{% url 'post:delete_post' post.slug %}" id="delete">#}
                                        {#{% csrf_token %}#}
                                        {#<i  class="fas fa-trash-alt tm-trash-icon"></i>#}
                                    {#</form>#}
                                    </td>
                            </tr>
                        {% endfor %}


<script>
        function deletePost(slug) {
            let action = confirm('Are you sure you want to delete this post?');
            if (action !== false) {
                $.ajax({
                    method: 'POST',
                    url: '{% url 'post:delete_post'%}',
                    success: function (data) {
                        if (data.delete()) {
                            $('#post_table').remove()
                        }
                    }
                });
            }
        }

    </script>

Очевидно, что это error, который у меня есть в настоящее время.

Reverse for 'delete_post' with no arguments not found. 1 pattern(s) tried: ['posts/(?P<slug>[-a-zA-Z0-9_]+)/delete/$']

Технически мне просто нужно ping с правильным DeleteView url с правильным slug, нужно ли анализировать json в DeleteView?

1 Ответ

0 голосов
/ 29 марта 2020

В любом случае нашел решение.

Изменил мой view на

class DeletePost(CsrfExemptMixin, SingleObjectMixin, View):
    model = Post

    def post(self, *args, **kwargs):
        self.object = self.get_object()
        self.object.delete()
        data = {'success': 'OK'}
        return JsonResponse(data) 

и изменил ajax request

var slug = document.getElementById('delete-icon').getAttribute('data-id');
        function deletePost() {
            let action = confirm('Are you sure you want to delete this post?');

            let url = '/posts/' + slug + '/delete/';
            if (action != false) {
                $.ajax({
                    method: 'POST',
                    url: url,
                    dataType: 'json',
                    success: function (data) {
                        $('#post_table').remove()
                    }
                });
            }
        }
...