Django – #47 – REST API cz. 22 – Zastosowanie techniki AJAX do API DRF w aplikacji Django – Update
Wprowadzenie.
Do tej pory poznaliśmy jak przy pomocy techniki AJAX odczytać listę rekordów z bazy danych, jak odczytać pojedynczy rekord oraz jak utworzyć nowy rekord w bazie danych. W tym wpisie przedstawiłem kolejną funkcjonalność, jaką jest edytowanie konkretnego rekordu.
Zakres artykułu.
- Zastosowanie techniki AJAX do API DRF w aplikacji Django – Update
Zastosowanie techniki AJAX do API DRF w aplikacji Django – Update
Załóżmy, że chcemy zrealizować funkcjonalność edytowania wypożyczeń w bazie danych. W tym celu będziemy potrzebowali pola wejściowego input, w którym będziemy umieszczali id wypożyczenia. Książkę, którą chcemy podmienić, będziemy jak poprzednio wybierać z pola select, pole select jak w poprzednim wpisie ma być aktualizowane po naciśnięciu przycisku. Gdy wprowadzimy id wypożyczenia i wybierzemy nową książkę, to przy pomocy kolejnego przycisku ma być zrealizowana edycja rekordu z wypożyczeniem.
Przejdźmy w pierwszym kroku standardowo do napisania funkcji widoku. Funkcja ta wygląda niemalże identycznie jak funkcja widoku do tworzenia nowych rekordów. Jedyna zmiana, jaką musimy wprowadzić, jest taka, że zamiast metody request.post, musimy zastosować metodą request.put. W tej metodzie musimy zmienić adres URL, który zawiera id wypożyczenia i jest zmapowany na funkcję edycji.
Następnie w pliku urls.py wykorzystajmy funkcję path(), w której zmapujemy adres URL na napisaną wyżej funkcję.
Przejdźmy teraz do szablonu, który stworzyliśmy w poprzednim wpisie i dodajmy do niego kod html i javascript. W kodzie html stwórzmy pole input, select, dwa przyciski (jeden do pobrania listy książek, a drugi do edycji wypożyczenia) i div jako kontener dla naszych danych.
W kodzie javascript należy dodać dwie funkcje. Jedna funkcja będzie obsługiwała przycisk z pobieraniem listy książek, natomiast druga będzie obsługiwała przycisk z edycją rekordu z wypożyczeniem.
Skrypt js, który realizuje pobranie listy książek, jest taki sam jak we wpisie gdzie tworzyliśmy nowy rekord.
W drugim skrypcie obsługującym przycisk edycji rekordu musimy jedynie pobrać wartość id wypożyczenia i umieścić go w danych wysyłanych na serwer. Pozostałe funkcjonalności zostały opisane w poprzednich wpisach.
Po stworzeniu całej funkcjonalności przejdźmy do przeprowadzenia prostych testów. W przeglądarce wpiszmy jak poprzednio adres 127.0.0.1:8000/ajax/borrows/.
Sprawdźmy, jakie jest nasze ostatnie wypożyczenie, korzystając z poprzednio napisanych funkcjonalności.
Gdy już mamy id wypożyczenia pobierzmy jeszcze dane pojedynczego rekordu, również przy pomocy wcześniej napisanej funkcjonalności.
Przejdźmy teraz do miejsca, gdzie widoczny jest nasz nowo napisany kod. Wprowadźmy id wypożyczenia, pobierzmy listę książek, wybierzmy nową książkę i naciśnijmy na przycisk Update borrow.
Jeżeli wszystko przebiegło pomyśle, to w zawartości tagu div powinniśmy zobaczyć kod statusu 200. Możemy teraz jeszcze raz pobrać dane wypożyczenia i sprawdzić, czy rzeczywiście dane zostały podmienione.