我很好奇是否有合理的方法来使用(惊人的)django-debug-toolbar和AJAX查询。
例如,我使用带有一堆参数的jQuery $ .get来命中Django URL并将其加载到内联中。如果我有错误,它不会在工具栏上注册。我也不能通过复制AJAX URL来使用它,因为DDT附加到响应的body标签,并且包含具有AJAX响应的body标签没有任何意义。
任何方向都会有所帮助!谢谢!
我之前遇到过同样的问题!当我正在做越来越多的AJAX重型应用程序时,我发布了一个Django Application和一个Chrome extension,它们一起解决了这个问题。
所有信息都在github存储库中。
我编写了可以添加到Django调试工具栏的Request History Panel for Django Debug Toolbar来查看当前请求之外的请求(包括AJAX请求)。
通过pip安装:
pip install django-debug-toolbar-request-history
在settings.py中添加'ddt_request_history.panels.request_history.RequestHistoryPanel'
到DEBUG_TOOLBAR_PANELS
例如:
DEBUG_TOOLBAR_PANELS = [
'ddt_request_history.panels.request_history.RequestHistoryPanel', # Here it is
'debug_toolbar.panels.versions.VersionsPanel',
'debug_toolbar.panels.timer.TimerPanel',
'debug_toolbar.panels.settings.SettingsPanel',
'debug_toolbar.panels.headers.HeadersPanel',
'debug_toolbar.panels.request.RequestPanel',
'debug_toolbar.panels.sql.SQLPanel',
'debug_toolbar.panels.templates.TemplatesPanel',
'debug_toolbar.panels.staticfiles.StaticFilesPanel',
'debug_toolbar.panels.cache.CachePanel',
'debug_toolbar.panels.signals.SignalsPanel',
'debug_toolbar.panels.logging.LoggingPanel',
'debug_toolbar.panels.redirects.RedirectsPanel',
'debug_toolbar.panels.profiling.ProfilingPanel',
]
我最近遇到了这个问题。我的快速肮脏但工作的解决方案只是添加一些HTML视图来灵活地使用相同的代码。
例如,如果我可以在NewRelic中看到我的网站90%的时间用于对/ search_for_book?title =的ajax调用,我的代码可能如下所示:
views.py:
def search_for_book(request, title):
data = _search_for_book(title)
return json_response(data)
def test_search_for_book(request, title):
data = _search_for_book(title)
return http_response(data)
瓶颈将出现在_search_for_book代码中;我们是否通过ajax调用它与诊断其低效率无关(在我的情况下,至少; YMMV)
Ddt将自己插入到响应中,这意味着没有标准的方法来浏览其面板以获取AJAX请求。此外,AJAX响应可以是JSON格式,这使得ddt无法插入它。
就个人而言,我会找到一种将ddt输出记录到文本文件的方法,或者它可能支持客户端 - 服务器架构,其中客户端在AJAX请求处理程序中工作并将数据发送到服务器?我不知道有什么可能,因为那里有十几个ddt克隆。