6

我陷入了困境。我正在使用 JS 助手。我使用了以下代码。

<?php $this->Js->get('#client_id')
        ->event('change', $this->Js->request(array('action' => '../ajax/get_client_location_and_process'),
                   array('update' => '#client_location_process',
                     'async' => false, 
                     'dataExpression' => true,
                     'method' => 'post',
                     'evalScripts' => true,
                     'data' => $this->Js->serializeForm(array('isForm' => True, 'inline' => True))
                     )
                   )
        );

我想在页面加载时触发更改事件。如果我使用的是 document.ready 方法,那么它不起作用。而且我找不到可以在控件上显式触发某些事件的 JS Helper 方法。请建议代码如何在我需要时在表单元素上执行类似 JQuery trigger() 的功能。

4

1 回答 1

13

由于您已经.trigger()在 jQuery 中找到了相关信息,因此您可以将它与您的视图代码一起使用:

<?php 
    // Your view code
?>
<script>$('#client_id').trigger('change');</script>

或者,如果您仍然喜欢通过 PHP 来做,您也许可以制作自己的助手,例如:

<?php 
class ArunjsHelper extends AppHelper {
    public $helpers = array('Html');

    function trigger($element, $event, $options = array()) {
        return $this->Html->scriptBlock("$('$element').trigger('$event');");
    }
}

添加ArunjsHelper$helpers控制器:

<?php
class SomeController extends Controller {
    public $helpers = array('Arunjs');

    // Your controller code
}

然后您可以从视图中调用它:

<h1>Hello</h1>
<p>Your usual view HTML code</p>

<?php // Trigger the change event ?>
<?php echo $this->Arunjs->trigger('#client_id', 'change'); ?>
于 2012-07-20T14:22:04.957 回答