CakePHP с jQuery (Javascript / Ajax) простая ссылка и обновление - что я делаю не так? - PullRequest
0 голосов
/ 20 июля 2011

Я просто пытаюсь использовать jQuery для распечатки содержимого действия. Но я не могу заставить свой div обновляться с отраженным контентом. Что я делаю не так?

birds_controller.php

...
    var $helpers = array('Js', 'Html', 'Ajax');
    var $components = array('RequestHandler');

function birds_ajax_1() {
    function birds_ajax_1_func_1() {
        $this->autoRender = false;
        echo "Text from Ajax clickaroo.";
    }
}
...

birds_ajax_1.ctp

<?php
    echo $ajax->link('Ajax Link', array('controller' => 'birds',
    'action' => 'birds_ajax_1_func_1'), 
         array('update' => 'ajax_div', 'complete' => 'alert("Ok.")'));
?>

<div id="ajax_div"></div> <!-- echoed text is not showing here? -->

default.ctp

...
echo $this->Html->script('jquery'); // Yes. My jQuery is being pulled in OK.
...

...
echo $this->Js->writeBuffer();
...

Это то, что сбрасывается в мой источник:

...
        <a href="/php/cake_app_birds_v1.3/birds/birds_ajax_1_func_1"     id="link2019467549" onclick=" event.returnValue = false; return false;">link1</a><script     type="text/javascript">

//<![CDATA[
Event.observe('link2019467549', 'click', function(event) { new Ajax.Updater('ajax_div','/php/cake_app_birds_v1.3/birds/birds_ajax_1_func_1',     {asynchronous:true, evalScripts:true, onComplete:function(request, json) {alert("Ok.")},     requestHeaders:['X-Update', 'ajax_div']}) }, false);
//]]>

1 Ответ

2 голосов
/ 20 июля 2011

birds_controller.php

var $helpers = array('Js' => array('Jquery'), 'Html', 'Ajax');
var $components = array('RequestHandler');

function birds_ajax_1() {
    if ($this->RequestHandler->isAjax()) {
    $this->render('/elements/birds_ajax_1'); // this birds_ajax_1.ctp contains the output into the #ajax_div.
    }
}

birds_ajax_1.ctp

<?php
// Note I am not using the $ajax->link(...
echo $this->Js->link('Ajax Link', array('controller' => 'birds',
'action'     => 'birds_ajax_1'), array('update' => '#ajax_div'));

?>

<div id="ajax_div"></div>

Ничего не изменилось в default.ctp.

Надеюсь, что это поможет кому-то еще, кто может пережить путаницу, через которую я только что прошел! Рад, что нашел свет! Теперь о некоторой сортировке jQuery? Ох, мальчик.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...