ImpressPages 4: правильный способ отправки данных страницы через ajax
Я хочу создать страницу ajax, и мне было интересно, как это сделать правильно? По сути, мне просто нужно получить данные страницы и заблокировать контент.
На данный момент у меня есть быстрое и грязное решение для проблемы, печатая json в событии ipBeforeResponceSent и выходя, но это уродливо..
class Event{
public static function ipBeforeResponseSent($event){
$ajax = ipRequest()->getQuery('ajax');
if ($ajax){
$page = ipContent()->getCurrentPage();
$data['status'] = 'success';
$data['url'] = $page->getLink();
$data['page'] = ipContent()->getBlockContent('main');
$data['title'] = $page->getTitle();
$data['id'] = $page->getId();
$data['pageorder'] = $page->getOrder();
$data['parent'] = $page->getParentId();
$data['timestamp'] = time();
exit(json_encode($data, true));
}
}
}
Javascript сторона:
$.getJSON(PAGE_URL, {ajax: 'true'}, function(responce) {
if (responce.status == 'success'){
/***/
}
});
Может быть, самым чистым решением было бы просто отправить ссылку на контроллер моего плагина?
2 ответа
Правильное использование AJAX:
передать два параметра:
sa: 'Plugin.Action' securityToken: ip.securityToken (если вы находитесь в JavaScript)
затем создайте действие контроллера и верните объект ответа json:
вернуть новый \Ip\Response\Json($data);
Вот вся эта информация в деталях http://www.impresspages.org/docs/controller
Я предполагаю, что если у вас есть PAGE_URL
, вы должны быть в состоянии использовать page id
, тоже.
Если эта функциональность связана только с этим конкретным сайтом, используйте Application
плагин и его PublicController.php
который уже на месте.
public function getPageAjax()
{
// Allowing only post actions
ipRequest()->mustBePost();
// Getting page ID from posted data
$pageId = ipRequest()->getPost('pageId');
// Get page object
$page = ipContent->getPage($pageId);
if ($page != null) {
$data = array();
// Do what you need
return \Ip\Response\JsonRpc::result(array('data' => $data));
} else {
return \Ip\Response\JsonRpc::error("Page not found");
}
}
Javascript будет выглядеть примерно так:
function applicationGetPageAjax(pageId) {
var postData = {
'pa': 'Application.getPageAjax',
'pageId': pageId,
'jsonrpc': '2.0'
};
$.ajax({
url: ip.baseUrl,
data: postData,
dataType: 'json',
type: 'POST',
success: function (response) {
if (response && response.result) {
// Do what you want with response
alert(response.result.data);
} else if (response && response.error && response.error.message) {
alert(response.error.message);
} else {
alert('Unknown response.');
}
},
error: function (response) {
alert('Unexpected error.' + response.responseText);
}
});
}
Я не проверял это. Используйте это как принцип. Вы можете найти несколько примеров похожих действий AJAX в ядре.