일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
- 알고리즘 풀이
- Django
- django rest framework
- 장고
- django widget
- 파이썬
- 알고리즘
- es6
- HTML
- js
- API
- web
- react
- Git
- Algorithm
- AWS
- django ORM
- 파이썬 알고리즘
- c++
- MAC
- 백준
- PYTHON
- java
- CSS
- DRF
- form
- javascript
- 알고리즘 연습
- Baekjoon
- 알고리즘 문제
- Today
- Total
목록Django (84)
수학과의 좌충우돌 프로그래밍
삭제 시 경고창 띄워주기 현재 post 한 글과 댓글이 삭제 버튼을 누르게 되면 망설임없이 바로 삭제 된다. 삭제 시에는 복원이 불가능하고 실수할 가능성이 있기 떄문에 경고창을 띄워서 이를 해결하자. post한 글과 댓글 경고창을 처리한 방식의 약간의 차이가 있어서 따로 다뤄주겠다. post 글 삭제 경고창 우선 기존의 삭제는 a 태그를 통해서 글을 삭제하는 기능을 수행하도록 url을 넘겨주었다. Delete 이제 바로 url을 넘겨주지 않고 modal 을 띄워준 후 modal 에서 삭제하기 를 누를 시 이 url로 넘어가도록 하겠다. 기존의a 태그를 수정해주자. Delete data-toggle="modal": 모달 창을 여는 역할 data-target="#CatModal": 모달의 id로 연결해주는 ..
js 로 Django 값 받아오기 기본적으로 Django의 파이썬 변수는 템플릿 변수를 통해서 값을 넘겨준다. 하지만 기본적인 템플릿 변수만으로는 제한사항이 있었다. 우선 파이썬 views.py 에서 정의한 딕셔너리 타입의 값을 js 로 넘겨주고자 하였다. view.py choices = Choice.objects.filter(vote_id=cat.vote.id) choices_name = [choice.as_dict() for choice in choices] as_dict() 는 models.py 에서 정의한 메소드로 model.py의 일부는 다음과 같다. models.py class Choice(models.Model): vote = models.ForeignKey(Vote,on_delete=mod..
글 삭제 및 수정 교내 주인 없는 고양이들을 관리해줄 수 있는 사이트를 제작중이다. home.html 에 접속하면 여러 고양이들의 존재하고 각 고양이를 클릭하면 localhost:8000/detail/ 로 이동하여 detail.html 에서 상세 정보를 확인할 수 있다. 이 상황에서 고양이가 학교를 떠나서 고양이 정보를 담은 글을 삭제하거나 정보를 수정해야할 때, 어떻게 해야하는지 알아보자. [ 글삭제 ] 먼저 글을 삭제하는 기능을 구현해보자. 각 고양이를 클릭하면 detail.html 으로 이동하므로 이 안에 삭제 버튼을 넣어주자. detail.html 외적은 부분은 신경쓰지않고 단순하게 텍스트로 넣어주었다. a 태그 는 delete 라는 url 을 가진 주소로 이동하며 cat.id 를 넘겨준다. ca..
안녕하세요 강민성입니다. 이번 시간에는 app 재사용에 대해서 알아보도록 하겠습니다. 우리가 app 을 기능별로 세분화 하는 이유가 바로 재사용 때문이었습니다. 이 방법을 알아보도록 하겠습니다. app 재사용 하는 법 재사용의 원리 app 을 재사용하기 위해서는 재사용할 app 을 먼저 패키징 해줘야합니다. 패키징이라고 함은 app 을 다른 프로젝트에서 가져가서 사용할 수 있도록 포장하는 일이라고 할 수 있습니다. 그리고 이미 포장을 푸는 방법은 해본 적이 있으실 겁니다. pip install {패키지 이름} 다음과 같은 방식으로 패키지를 풀어줄 수 있습니다. 패키징 하는 법 그럼 패키징하는 방법에 대해서 알아보겠습니다. 패키징을 하기 위해서는 4개의 파일이 필요합니다. 4개의 파일의 이름과 각각의 역할..
안녕하세요 강민성입니다. 이번 시간에는 form 에 대해서 알아보겠습니다. 앞선 포스팅에서도 form을 다룬 적이 있습니다. blog에 글을 쓰기 위한 form도 만들어 보았고, 회원가입, 로그인 하는 form도 만들어 보았습니다. 하지만 이 때는 단순히 html로 만들었었는데, 장고에서는 모델과 대응시켜 이 form을 만들어 줄 수 있습니다. 이럴 경우, 보다 더 편하게 여러가지 기능을 추가할 수 있는데 이에 대해서 알아보도록 하겠습니다. form을 이용해 입력공간 만들기 마찬가지로 blog project에서 이어서 진행하도록 하겠습니다. 먼저 form.py를 원하는 앱 안에 만들어줘야 합니다. form의 위치는 중요하지 않지만 blog/models.py 의 class 를 불러올 것이기 때문에 편의상 ..
안녕하세요 강민성입니다. 이번 시간에도 마찬가지로 blog project를 이어서 진행해보도록 하겠습니다. 글을 계속 추가할수록 글은 아래로 쌓이게 됩니다. 하지만 대부분의 웹사이트는 일정 수준 이상 쌓이면 다음 페이지로 넘어갈 수 있도록 구현 되어 있습니다. 이를 pagination 이라고 합니다. pagination을 알아보자 한 페이지에 3개의 글이 올 수 있도록 해보겠습니다. 장고에서 역시 이를 위한 클래스가 정의되어 있습니다. 먼저 이를 import 한 후 진행하겠습니다. from django.core.paginator import Paginator blog/view.py 설명할 부분이 많아 전체적인 코드를 먼제 보고 한 줄 씩 설명하겠습니다. blog_list = Blog.objects.all..
안녕하세요 강민성입니다. 이번 시간에는 회원가입과 로그인, 로그아웃 기능을 구현해보도록 하겠습니다. 이 기능들은 고맙게도 장고에서 제공을 해주고 있기 때문에 이 함수들을 가져다가 쉽게 구현할 수 있습니다. 그리고 실습을 시작하기 전에 알아야 하는 개념이 있습니다. 바로 http method인데 가볍게 짚고 넘어가도록 하겠습니다. http 상에서 정보를 주고 받는 방식 http 상에서 정보를 주고 받는 방식은 여러 개 존재합니다. 정보를 주고 받는 방식을 굳이 나눈 이유는 무엇일까요? 아래 코드는 blog app 에서 글을 쓰는 입력창에 해당하는 html 입니다. method를 따로 지정하지 않고 form으로 넘겨주면 GET방식으로 넘어오기에, views에서도 GET 을 사용하여 정보를 받아주고 있습니다...
안녕하세요 강민성입니다. 저번 시간 까지 blog 프로젝트를 진행하였는데 이번 포스팅에서도 이를 베이스로 진행하도록 하겠습니다. 현재까지 project의 urls 를 확인해보면 다음과 같습니다. 아직 앱은 두 개 밖에 만들지 않았고, 하나의 앱은 url도 하나밖에 설정하지 않았습니다. 하지만 점점 복잡해지고, 앱이 추가될수록 복잡함은 더 심해질 것입니다. 그래서 url 을 효율적으로 관리하는 방법이 있습니다. 이를 알아보도록 하겠습니다. url 을 효율적으로 관리해보자 다시 한 번 urls 을 봐보도록 하겠습니다. 12~14 번째 줄을 보면 blog/~~ 를 가지는 url 로서 맨 앞에 blog 라는 공통적인 특징이 있습니다. 이들을 하나로 묶어줄 수는 없을까요? 그러기 위해서는 묶어주고 싶은 앱 안에 ..
안녕하세요 강민성입니다. 저번 시간까지 배웠던 내용을 기초로 하여 blog의 기능들을 만들어보도록 하겠습니다. 지난 시간 배웠던 내용을 확인하려면 여기를 클릭하세요. 다만, 이 부분에서 다루는 내용은 html 이나 css 가 아니므로 bootstrap을 사용하도록 하겠습니다. bootstrap을 통해 원하시는 대로 꾸미면 되겠습니다. 제 결과물은 다음과 같습니다. 본격적으로 오늘 배울 내용에 대해서 알아보겠습니다. 현재 블로그의 글들은 제가 admin 페이지가 들어가서 만든 글들입니다. 그렇게 때문에 blog 관리자인 저는 글을 쓸 수 있지만, 이용자들을 아직 글을 쓸 수 없습니다. 그래서 이 기능을 추가해보도록 하겠습니다. 이용자도 글을 작성할 수 있도록 해보자 사용자가 게시물의 정보를 기입하는 htm..
안녕하세요 강민성입니다. 이번에는 저번 시간부터 만들어오던 blog 프로젝트를 좀 더 업그레이드 시켜보도록 하겠습니다. 먼저 업그레이드 내용부터 알아보도록 하겠습니다. 1. 글자 수 제한 2. ...more 에 링크 달기 3. 링크를 클릭했을 때 detail.html 페이지 내보내기 pk, path converter, get_object_or_404란? 글자 수를 제한하기 위해, 그리고 실습 진행을 위해 admin에서 여러 개의 blog 객체를 만들어 놨습니다. 1. 글자수 제한 글자수 제한부터 해보도록 하겠습니다. 글자를 제한하는 건 모델에 함수 하나만 추가해주면 됩니다. 함수를 만들고 본문 내용 body를 슬라이싱을 이용해서 100글자로 제한하였습니다. 그리고 home.html 을 다음과 같이 수정해..