gpt4 book ai didi

php - Symfony2 Controller 、 View 和 JavaScript

转载 作者:行者123 更新时间:2023-11-28 20:39:57 25 4
gpt4 key购买 nike

我正在 Symfony2 下做一个项目。我在同一个 Controller 中获得了两个操作(历史、日历)和两个 View 。

我的历史操作调用日历操作,默认值为本周。然后它渲染历史 View ,历史 View 本身渲染日历 View 。

第一个问题,它的工作原理,但在日历 HTML View 之前,symfony 添加了一句话:HTTP/1.0 200 OK Cache-Control: no-cache Date: Wed, 30 Jan 2013 10:17:13 GMT 我怎样才能删除这句话?

我这样做是因为我得到了一些 JavaScript 链接,这些链接通过调用日历 Controller (上一周或下一周不同)使日历转到上一周或下一周,并在他的 div 中打印新日历。这有点工作,但我有一些奇怪的行为。我已将 JavaScript 代码放入日历 View 中。我第一次加载页面 JavaScript 在代码源中显示并工作。如果我按下“上一周”或“下一周”按钮,日历 Controller 会返回新的日历 View ,但没有 javascript。我在 firebug 中再也看不到 JS 了。但是(这是最奇怪的部分),JavaScript 仍然有效(如果我按下按钮,它会重新加载日历 div)。

这是我的一些代码:

calendar.html.twig:

<script type="text/javascript">
$('.nextWeek').live('click', function () {
$.ajax({
url: 'prof_calendrier/{{ nextWeek }}',
success: function (html) {$('.calendrier').html(html);}
});
});
$('.lastWeek').live('click',function () {
$.ajax({
url: 'prof_calendrier/{{ lastWeek }}',
success: function (html) {$('.calendrier').html(html);}
});
});
</script>
<p>Week from {{datesWeek.0}} to {{datesWeek.6}}</p>
[...] display rest of informations

prof_calendrierAction(日历操作):

public function prof_calendrierAction ($date) {
$erreur='';
$message='';
$session = $this->container->get('session');

[...] // lot of operations

return $this->render('CDUserBundle:Default:prof_calendrier.html.twig', array(
'next_cours' => $liste_prochains_cours,
'today' => date('D'),
'nextWeek' => $nextWeek,
'lastWeek' => $lastWeek,
'datesWeek' => $datesWeek
));
}

有人可以帮我吗?*

编辑:为了避免 HTTP 消息,我的历史操作不再调用日历操作。我渲染了历史,并且在历史 View 中,我得到了 ajax init,它将检查今天一周的日历操作。但是,当我使用“上周”或“下周”按钮刷新 JavaScript 时,html 会发生变化,但 JavaScript 不会更新。 JavaScript 是在日历 View 中编写的,那么为什么日历操作不会比第一次更多地返回 JS。

编辑²:我做了几次测试。我的上周/下周 JavaScript 按钮位于日历 View 中。就好像在此 View 中写入的所有 JS 行都被捕获并缓存一段时间一样。我的意思是我下周第一次按时,显示下周没有问题。第二次,firebugs 向我展示了两个 ajax 请求,一个用于同一周,一个用于一周后的请求。这就像如果第一行 JavaScript 行被保留并缓存,那么在下周的第二次按下时,它会调用旧的,然后调用新的......

最佳答案

您可以使用 Symfony 的响应组件从 Controller 发送特定响应。添加

use Symfony\Component\HttpFoundation\Response;

然后构建您的“html”变量响应并按如下方式发送:

return new Response($return,200,array('Content-Type'=>'application/json'));

这里,$return 是一个 json 实体。 200 是响应的状态码,'Content-Type'=>'application/json' 必须与 $return 的类型匹配。

这就是我对 Symfony2 calendar 的处理方式而且效果很好。

编辑 JS:您无法使用 twig 通过 ajax 更改您的 javascript。您应该在 JavaScript 中定义全局变量,并遵循您需要的任何参数。当您处理 ajax 响应时,可以在 javascript 中访问这些全局变量。例如,您可以在 Twig 中执行以下操作:

<script>
var globalMonth = {{ month }}; // set up the starting month
...

然后,当 ajax 发送响应时,您更新 globalMonth 并将其用于下一个 ajax 调用。

阿尔类

关于php - Symfony2 Controller 、 View 和 JavaScript,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14601767/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com