3

我正在开发的网站的结构是这样的:

设置时具有切换首页内容模块的功能$_GET['module'],例如:

function switchmodules()
{
    $module=$_GET['module'];
    switch($module)
    {
        case 'getnews': news(); break;
        default: def();
    }
}

如您所见,此开关为每个模块调用另一个函数。

例如,我写信getNews()以这种方式工作:

function getNews()
{
   $id=$_GET['id'];
   if(!id)
   {
       //CODE TO LIST ALL NEWS
   }
   if(isset($id))
   {
       //CODE TO GET ONLY 1 NEWS BY ID
   }

}

因此,如您所见,我没有为每个模块使用唯一的文件;模块的所有操作都是独特功能的一部分,其中再次切换动作以改变结果。

如果我想从数据库中获取新闻,我应该使用这样的 url:?index.php&module=getnews&id=1

我现在的问题是:
使用 jQuery 和$.ajax()方法,有没有办法使用这种基于 get 切换的函数的结构来获取新闻(例如)?还是我必须更改所有内容并为每个功能制作一个文件?

4

3 回答 3

1

您可以简单地通过 $.ajax() 调用相同的 url。对于 axjax 调用,唯一应该更改的是您不输出布局,而只输出新闻本身。

在 php 中,您可以检查 ajax 请求,例如

if (isset($_SERVER['HTTP_X_REQUESTED_WITH']) && strtolower($_SERVER['HTTP_X_REQUESTED_WITH']) == 'xmlhttprequest') {

    // dont output layout
}
于 2012-04-14T20:04:09.203 回答
1

如果此代码位于“test.php”中,您可以执行以下操作:

<script>
    $.get(
        '/test.php',
        {
            module: 'news',
            id: 1
        },
        function( data ) {
            alert( data );
        }
    );
</script>

并且 js 将使用所需的参数向 test.php 发送 GET 请求。然后您的服务器脚本将决定如何处理请求。

于 2012-04-14T20:07:41.637 回答
0

jQuery

$(document).ready( function() {
    var form = '#my_awesome_form';

    $(form + ' input[type=submit]').click(function(e) {
        e.preventDefault();

        $.ajax({
            type: "GET",
            url: 'index.php',
            data: $(form).serialize(),
            success: function( response ) {
                alert('DONE!');
            }
        });
    });
});

HTML

<form id="my_awesome_form" // OTHERS PROPERTIES //>
    // LOT OF FIELDS HERE //
    <input type="submit" value="Send">
</form>
于 2012-04-14T20:12:35.923 回答