Django에서 블로그 시스템 검색 기능 구현
간단한 소개
4
4
구현은 다음과 같습니다.
# 1. :
def search(request):
q = request.GET.get('q') #
contexts = Article.objects.all().order_by('-pub_date')[:5] #
search_list = Article.objects.filter(title__icontains=q) #
error_msg = 'No result'
return render(request, 'blog/search.html', {'search_list': search_list,
'error_msg': error_msg,
'contexts': contexts})
'q' 는 전방 input 탭name 속성의 이름입니다. 잠시 후에 다시 이야기합시다.코드의 두 번째 줄은 전방 입력 상자에 있는 키워드를 가져오는 것이다.셋째, 넷째 줄은 데이터베이스에서 조회하고 셋째 줄은 모든 파일을 조회하며 넷째 줄은 제목에 키워드의 내용을 포함한다.어떤 글에서는 q가 비어 있는지 판단하는데 사실은 전혀 필요하지 않으며 전단 html 코드에서 설명할 수 있다.
# 2. :
class Article(models.Model):
title = models.CharField(max_length=200)
category = models.CharField(max_length=100, default='') #
body = MDTextField()
pub_date = models.DateTimeField('datepublished',default=timezone.now)
def __str__(self):
return self.title
모델에 만들어진 몇 개의 필드, 제목, 분류, 주체 내용, 발표 시간.
# 3. html :
input 탭에서name의 값 q는 검색 방법의 q와 같고 Required도 있습니다. 이 값은 입력이 비어있으면 안 된다는 것을 설명합니다. 이 값이 있으면 백엔드의 검색 방법에서 q가 비어있는지 판단할 필요가 없습니다.action 설정 URL.
# 4. url :
path('search/', views.search, name='search'),
# 5. :
{% if search_list %}
{% for search in search_list %}
{
{ search }}
{% endfor %}
{% else %}
{
{ error_msg }}
{% endif %}
검색 문장 전시 내용은 css 최적화가 필요합니다.
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
Python의 None과 NULL의 차이점 상세 정보그래서 대상 = 속성 + 방법 (사실 방법도 하나의 속성, 데이터 속성과 구별되는 호출 가능한 속성 같은 속성과 방법을 가진 대상을 클래스, 즉 Classl로 분류할 수 있다.클래스는 하나의 청사진과 같아서 하나의 ...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.