内容简介:使用可检查过后我的页面里都是有查源码加调试输出找到问题的原因:
使用 spatie/laravel-pjax
的时候遇到总是 abort(422)
的情况,查了一圈大多说原因是渲染的页面里找不到监听的 pjax container。
可检查过后我的页面里都是有 id="pjax-container"
的,请求头里也有 X-PJAX-CONTAINER: #pjax-container
。
查源码加调试输出找到问题的原因:
spatie/laravel-pjax
里使用了 Symfony\Component\DomCrawler\Crawler
来检查渲染的 DOM 中是否存在指定的 X-PJAX-CONTAINER
。
// Middleware/FilterIfPjax.php
protected function filterResponse(Response $response, $container)
{
$crawler = $this->getCrawler($response);
$response->setContent(
$this->makeTitle($crawler).
$this->fetchContainer($crawler, $container)
);
return $this;
}
abort(422)
发生在 fetchContainer()
中:
protected function fetchContainer(Crawler $crawler, $container)
{
$content = $crawler->filter($container);
if (!$content->count()) {
abort(422);
}
return $content->html();
}
注意到在 filterResponse()
中是把当前的 $response
传给了 $crawler
的,那么如果当前的 $response
其实是个错误页面呢?这里就会发生找不到 #pjax-container
的情况了。
输出一看果然, $response
是个异常信息页面。我遇到的问题是忘了 migrate
。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
React开发实战
[美] Cássio de Sousa Antonio / 杜伟、柴晓伟、涂曙光 / 清华大学出版社 / 2017-3-1 / 58.00 元
介绍如何成功构建日益复杂的前端应用程序与接口,深入分析 React库,并详述React生态系统中的其他工具与库,从而指导你创建完整的复杂应用程序。 你将全面学习React的用法以及React生态系统中的其他工具和库(如React Router和Flux 架构),并了解采用组合方式创建接口的佳实践。本书简明扼要地讲解每个主题,并呈现助你高效完成工作的细节。书中严谨深刻地讲述React中重要的功......一起来看看 《React开发实战》 这本书的介绍吧!