我在PHP中构建了一个单点输入控制器(所有路由都通过index.php)。它工作得很好,但是我在用ajax调用设置$ _POST变量时遇到了问题。
我猜是因为ajax调用的URL是/ submit,而不是/index.php
$ url_page是浏览器URL中的页面名称。这是在函数中处理的,我在此示例中省略了
switch($url_page)
{
case '':
echo 'When login works this will redirect you to to correct page';
break;
case 'admin':
$template_page->set_values('URL', URL);
$template_page->set_values('PATH', PATH);
$template_page->set_values('NAVIGATION', '');
$template_page->set_values('SIDENAVIGATION', '');
$template_page->pageContet('admin.html');
echo $template_page->build_template();
break;
case 'student':
$template_page->set_values('URL', URL);
$template_page->set_values('PATH', PATH);
$template_page->set_values('INCJS', URL.'/assets/js/studentjs.js');
$template_page->set_values('NAVIGATION', file_get_contents(TEMPLATES.'/studentNav.html'));
$template_page->set_values('SIDENAVIGATION', file_get_contents(TEMPLATES.'/userSideNav.html'));
$template_page->pageContet('students.html');
echo $template_page->build_template();
break;
case 'submit':
cannot access $_POST here
break;
default:
header('Location:'.URL.'/404.html') ;
break;
}
这是Ajax
$('.navicagtionClass > li > a').click(function() {
var page = $(this).attr('value');
var obj = {};
obj['page'] = page;
$.ajax({
url: "/submit",
type: "POST",
data: obj,
dataType: "json",
success: function(data) {
console.log(data);
document.getElementById('PageContent').innerHTML = data.a;
},
error: function(xhr, status, err) {
console.log(err);
}
});
});
最佳答案
如果我正确理解您的方法,则无法将当前页面用作AJAX处理器文件。您需要一个单独的PHP文件来处理AJAX,并将其返回给index.php。
在下面引用的源代码中,请特别注意前缀为“尝试此操作,您会明白我的意思”的示例-试试看。
资源:
values not updated after an ajax response