点击链接时的Yii2加载模式

时间:2016-05-14 08:45:33

标签: javascript php jquery twitter-bootstrap yii2

这是我的 _form

<div class="row">       
    <div class="col-sm-4">
        <?= $form->field($model, 'otm_grading_system')->dropdownList(ot\TestGradingSystem::getTestGradingSystem(), [
            'prompt' => Yii::t('ot', '--- Select Grading System ---'),
            'onchange' => '$.get( "'.Url::toRoute('dependent/get-grading-system').'", { id : $(this).val() }).done(function(data) {
                $( "#seeHere").html(data);
            });'
        ]) ?>
    </div>
    <div class="col-sm-4" id="seeHere">
    </div>
</div>

在表单dropDownList上更改事件获取url。显示在 DependandController.php

下面
class DependentController extends \yii\web\Controller
{
  public function actionGetGradingSystem($id)
  {
     return Html::a('See Here 123', ['test-grading-system/view', 'id' => $id], ['id' => 'seeHereMdl', 'title' => Yii::t('ot', 'View Result')]);
  }
}

这是模态加载js

<?php
  $this->registerJs(
   "$(document).on('ready pjax:success', function() {
     $('#seeHereMdl').click(function(e){
       e.preventDefault();      
       $('#grading-sys-modal').modal('show')
                  .find('.modal-content')
                  .load($(this).attr('href'));  
       });
     });
   ", $this::POS_HEAD);
?>
<?php
  yii\bootstrap\Modal::begin([
    'id'=>'grading-sys-modal',
    'size' => 'modal-lg'
  ]);
   yii\bootstrap\Modal::end();
?>

我的问题是,这无法以模态加载视图文件,但会重定向到此视图页。

1 个答案:

答案 0 :(得分:1)

这是一个事件处理问题(与yii无关),而不是:

$('#seeHereMdl').click(function(e){});

你应该试试:

$('body').on('click', '#seeHereMdl', function(e) {});

了解详情:Event binding on dynamically created elements?