django admin site search
1.1.0
โมดอลการค้นหาทั่วโลก/ไซต์สำหรับผู้ดูแลระบบ Django
model_char_fields
( default ): ค่า CharField
(และคลาสย่อย) ทั้งหมด พร้อมด้วย __icontains
admin_search_fields
: เรียกใช้เมธอด get_search_results(...) ของ ModelAdmin แต่ละตัวpip install django-admin-site-search
admin_site_search
ในการตั้งค่า INSTALLED_APPS
ของคุณAdminSiteSearchView
ให้กับ AdminSite ของคุณ: from django . contrib import admin
from admin_site_search . views import AdminSiteSearchView
class MyAdminSite ( AdminSiteSearchView , admin . AdminSite ):
...
admin/base_site.html
ใน templates/
directory ของคุณtemplates/
ไดเร็กทอรีของคุณอยู่ภายในแอป แอปนั้นจะต้องปรากฏใน INSTALLED_APPS
ก่อน แอปผู้ดูแลระบบที่กำหนดเองของคุณadmin_site_search
: {% extends "admin/base_site.html" %}
{% block extrahead %}
{% include 'admin_site_search/head.html' %}
{{ block.super }}
{% endblock %}
{% block footer %}
{{ block.super }}
{% include 'admin_site_search/modal.html' %}
{% endblock %}
{% block usertools %}
{% include 'admin_site_search/button.html' %}
{{ block.super }}
{% endblock %}
admin_site_search/head.html
ยังโหลด Alpine JS ด้วย/static/
เพื่อหลีกเลี่ยงการพึ่งพาภายนอกmodal.html
และ button.html
นั้นไม่ได้เข้มงวด แม้ว่าตำแหน่งแรกจะอยู่ในตำแหน่งระดับบนสุดก็ตาม{% block header %}
- ควรใช้ footer
มากกว่า class MyAdminSite ( AdminSiteSearchView , admin . AdminSite ):
# Sets the last part of the search route (`<admin_path>/search/`).
site_search_path : str = "search/"
# Set the search method/behaviour.
site_search_method : Literal [ "model_char_fields" , "admin_search_fields" ] = "model_char_fields"
def match_app (
self , request , query : str , name : str
) -> bool :
"""DEFAULT: case-insensitive match the app name"""
def match_model (
self , request , query : str , name : str , object_name : str , fields : List [ Field ]
) -> bool :
"""DEFAULT: case-insensitive match the model and field attributes"""
def match_objects (
self , request , query : str , model_class : Model , model_fields : List [ Field ]
) -> QuerySet :
"""DEFAULT: Returns the QuerySet after performing an OR filter across all Char fields in the model."""
def filter_field (
self , request , query : str , field : Field
) -> Optional [ Q ]:
"""DEFAULT: Returns a Q 'icontains' filter for Char fields, otherwise None
Note: this method is only invoked if model_char_fields is the site_search_method."""
def get_model_queryset (
self , request , model_class : Model , model_admin : Optional [ ModelAdmin ]
) -> QuerySet :
"""DEFAULT: Returns the model class' .objects.all() queryset."""
def get_model_class (
self , request , app_label : str , model_dict : dict
) -> Optional [ Model ]:
"""DEFAULT: Retrieve the model class from the dict created by admin.AdminSite"""
เพิ่มผลลัพธ์ TextField
เพื่อค้นหา
from django . contrib import admin
from django . db . models import Q , Field , TextField
from admin_site_search . views import AdminSiteSearchView
class MyAdminSite ( AdminSiteSearchView , admin . AdminSite ):
site_search_method : "model_char_fields"
def filter_field ( self , request , query : str , field : Field ) -> Optional [ Q ]:
"""Extends super() to add TextField support to site search"""
if isinstance ( field , TextField ):
return Q ( ** { f" { field . name } __icontains" : query })
return super (). filter_field ( query , field )
โปรดทราบว่าสิ่งนี้ไม่ได้ทำโดยค่าเริ่มต้นเนื่องจากเหตุผลด้านประสิทธิภาพ: __icontains
ในรายการข้อความจำนวนมากนั้นไม่เหมาะสม