在cakephp 3

时间:2017-03-21 16:06:04

标签: jquery ajax cakephp cakephp-3.4

我在CakePHP 3.4中工作

我正在向控制器发出Ajax请求,要求从数据库中获取一些数据并将其响应回视图。因为,返回的数据是一组数据,可以是1行到100行。我想创建一个单独的视图并将响应数据发送到该视图,然后用该视图替换div内容。

这就是ajax调用的方式

$('#trigger_connect_btn').click(function(e) {
    e.preventDefault();
    var data = {server_id : $('#server_id').val()};
    $.ajax({
        type: 'post',
        data: data,
        url: '/servers/trigger-connect',
        success: function(result){
            console.log(result);
        }
    });
});

triggerConnect()行动

public function triggerConnect()
{
    $this->autoRender = false;
    $id = $this->request->getData('server_id');

    $server = $this->UserServers->get($id);
    $ftp = new \FtpClient\FtpClient();
    $ftp->connect($server->server_url);

    $res = $ftp->login($server->server_username, $server->server_password);

    if ($res) {
        $response['code'] = 100;
        $response['type'] = 'Success';
        $response['message'] = 'Login Success';
        $response['content'] = $ftp->scanDir();
    } else {
        $response['code'] = 101;
        $response['type'] = 'Error';
        $response['message'] = 'Login Failed';
    }

    echo json_encode($response);
}

当前视图文件

<div id="response-content"></div>

此工作正常,返回的内容正在控制台中打印。我知道,我可以使用jQuery迭代数据并在视图中打印,但我想为它创建一个单独的视图文件,它将呈现返回的数据,然后用渲染视图更新当前视图文件中的div。

1 个答案:

答案 0 :(得分:1)

如果你想用它的视图文件加载特定的CakePHP方法,那么有jquery load方法。

$('#trigger_connect_btn').click(function(e) {
   e.preventDefault();
   $("#response-content").load("/servers/trigger-connect", {
       server_id : $("#server_id").val()
   });
});

上述脚本会将函数trigger-connect的相应视图加载到#response-content

现在注释掉/删除操作中的以下行,并确保已设置变量以便在相应的视图中根据需要进行迭代。

// $this->autoRender = false;