【问题标题】:how to put datepicker in controller in yii如何将日期选择器放入 yii 的控制器中
【发布时间】:2015-09-02 11:02:19
【问题描述】:

我在 yii 中有一个表单,表单中的一个字段是通过单击按钮来自控制器的。如果我传递文本字段而不是 datepicker 那么它可以工作,否则它会给出错误那么现在该怎么办?

我的表单代码如下:

            <div class="row buttonproduct" hidden>
                <input class="btn btn-primary add-product" style="margin-left: 0px;" type="button" value="Add Lease Agreement">
            </div>

表单中的脚本如下:

<script>

$('.add-product').live('click', function(){
        var value = parseInt(document.getElementById('service').value, 10);
        value = isNaN(value) ? 0 : value;
        value++;
        document.getElementById('service').value = value;

        $.ajax({
            url:"<?php echo Yii::app()->request->baseUrl;?>"+"/Landowner/addlease?id="+value,
            data:'req=add_more',
            dataType:'html',
            type:'POST',
            async: true,
            cache: false,
            success:function(resp){
                $('.addproduct').append(resp);
            },
            error:function(er){ 
                alert("An error has occured, Please reload/refresh the page and try again.");
            }
        });

   return false;
   });
   </script>

我的控制器代码是:

public function actionAddlease() {
    if (Yii::app()->request->isAjaxRequest) {
        $id = $_REQUEST['id'];
        $div = '<div class="row">';

        $data = $div.CHtml::label(Yii::t('LeaseAgreement[lease_agrmnt_id]', 'Lease Agreement ID '), 'LeaseAgreement[lease_agrmnt_id]');
        $data .= CHtml::textField('LeaseAgreement[lease_agrmnt_id][]', '', array('maxlength'=>'300')).'</div>';


        $data .= $div.CHtml::label(Yii::t('LeaseAgreement[lease_startdate]', 'Start Date '), 'LeaseAgreement[lease_startdate]');
        $data .= $this->widget('zii.widgets.jui.CJuiDatePicker', array(
                            'name'=>'LeaseAgreement[lease_startdate][]',
                            //'model'=>$model,
                            'id'=>'LeaseAgreement_lease_startdate',
                            //'value'=>Yii::app()->dateFormatter->format("'yy-mm-dd'",strtotime($model->datecolumn_name)),
                            'options'=>array(
                            'showAnim'=>'fold',
                            ),
                            'htmlOptions'=>array(
                            'style'=>'height:20px;'
                            ),
                    ));

        $data .= $div.CHtml::label(Yii::t('LeaseAgreement[filename]', 'Lease Agreement Document '), 'LeaseAgreement[filename]');;
        $data .= CHtml::fileField('LeaseAgreement[filename][]', '', array('maxlength'=>'300')).'</div>';

        echo $data;
    }
}

在这里,如果我不在这个函数中使用 datepicker,那么它的工作原理不是这样,那么错误在哪里。请帮助我被困在这里的任何人。

【问题讨论】:

  • 您应该按照规则在视图文件中使用它。
  • 对于日期选择器,您可以使用 UI 日期选择器,它将与类一起使用
  • 我知道,但我必须在控制器中编码,因为单击按钮会增加字段数量。
  • 检查我的回答是否有帮助

标签: php jquery ajax yii datepicker


【解决方案1】:

您可以使用Jquery ui,它将作用于输入类或 id

文本域代码

$data .= CHtml::textField('LeaseAgreement[lease_agrmnt_id][]', '', array('maxlength'=>'300','class'=>'datepicker')).'</div>';

jquery

<script>
  $(function() {
    $( ".datepicker" ).datepicker();
  });
  </script>

您可能需要为此包含 jquery Ui 文件。

【讨论】:

  • 我很高兴。我可以帮忙..:)
猜你喜欢
  • 2011-12-30
  • 1970-01-01
  • 1970-01-01
  • 2010-12-21
  • 1970-01-01
  • 2015-01-01
  • 1970-01-01
  • 2015-05-16
  • 1970-01-01
相关资源
最近更新 更多