【发布时间】:2014-01-10 16:48:59
【问题描述】:
我想像这样使用 jquery 自动完成功能进行 ajax 调用:
$("#register_player_team").autocomplete({
source: function( request, response ) {
$.ajax({
url: "{{path('volley_scout_getteams_data')}}",
dataType: "jsonp",
success: function( data ) {
console.log(data);
},
error: function (xhr, ajaxOptions, thrownError) {
console.log(xhr.status);
console.log(thrownError);
}
});
}
});
在我的 routing.yml 中,我定义了以下路由:
volley_scout_getteams_data:
pattern: /team/getteams
defaults: { _controller: VolleyScoutBundle:Team:getteams }
在我的 TeamController 中,我有一个名为 getteamsAction() 的操作:
public function getteamsAction()
{
$entityManager = $this->getDoctrine()->getManager();
// Get teams from database
$teams = $entityManager->getRepository('VolleyScoutBundle:Teams')->findAll();
foreach($teams as $team){
var_dump($team);
}
die();
}
(dump 和 die() 只是为了测试,我想看看他能不能找到链接)。 但是当我想进行 ajax 调用时,我总是会收到以下错误:
http://localhost:8080/volleyscout/web/app_dev.php/user/%7B%7Bpath('volley_s…)%7D%7D?callback=jQuery110207641139030456543_1389372448462&_=1389372448463 404 (Not Found)
由于某种原因,他找不到动作......有人知道我做错了什么吗?当我尝试这样的链接时:web/app_dev.php/team/getteams 我得到了团队的转储..
更新: 我的 javascript 链接在基本视图(树枝)中定义,如下所示:
{% block javascripts %}
{% javascripts
'@VolleyScoutBundle/Resources/public/js/jquery-1.10.2.min.js'
'@VolleyScoutBundle/Resources/public/js/*'
%}
<script src="{{ asset_url }}"></script>
{% endjavascripts %}
{% endblock %}
而 ajax 调用在我的 page.js 中:
(function () {
$("#register_userType").change(function(){
var value = $(this).find("option:selected").val();
if(value == 'P' || value == 'T'){
$('.teams').show();
}
else{
$('.teams').hide();
}
});
$("#register_player_team").autocomplete({
source: function( request, response ) {
$.ajax({
url: "{{path('volley_scout_getteams_data')}}",
dataType: "jsonp",
success: function( data ) {
console.log(data);
},
error: function (xhr, ajaxOptions, thrownError) {
console.log(xhr.status);
console.log(thrownError);
}
});
}
});
})();
更新 2: 我做了以下事情:
- 安装包
- 将包添加到我的 AppKernel
- 在app/config/routing.yml中注册了路由定义
- 已发布资产(php app/console assets:install --symlink web)
像这样将 2 个 javascript 行添加到我的 base.html.twig 中:
{% block javascripts %}
{% javascripts
'@VolleyScoutBundle/Resources/public/js/jquery-1.10.2.min.js'
'@FOSJsRoutingBundle/Resources/public/js/router.js'
'@VolleyScoutBundle/Resources/public/js/bootstrap.min.js'
'@VolleyScoutBundle/Resources/public/js/jquery-ui-1.10.3.custom.min.js'
%}
<script src="{{ asset_url }}"></script>
{% endjavascripts %}
<script src="{{ path('fos_js_routing_js', {"callback": "fos.Router.setData"}) }}"></script>
<script src="{{ asset('bundles/volleyscout/js/security.js') }}"></script>
{% endblock %}
但现在我得到了这个错误:
GET http://localhost:8080/volleyscout/web/app_dev.php/js/routing?callback=fos.Router.setData 500 (Internal Server Error) register:117
Uncaught Error: The route "volley_scout_getteams_data" does not exist.
这很奇怪。当我清除缓存时,它第一次完美运行。当我刷新时,它会显示错误...
【问题讨论】:
-
您的 javascript 是否位于树枝模板中?如果它在外部 javascript 文件中,twig 语法将不起作用。
-
我的 javascript 在我的 base.html.twig 中定义(我更新了我的开始帖子以获取更多信息)