如何在yii中创建自定义自动填充文本字段

时间:2013-01-07 14:12:25

标签: php jquery ajax autocomplete yii

我是yii的新手。我需要编写自定义yii自动完成。我知道CJuiAutocomplete就在那里。但我需要实现自己的自定义自动完成。任何人都可以指导我或帮助我开发自定义自动完成文本字段。在文本字段中显示名称时获取ID。

提前致谢

2 个答案:

答案 0 :(得分:5)

以下是网站控制器中的操作......

public function actionAutoComplete($term){

    $query = Yourmodel::model()->findallbyattributes( array('somecolumn'=>$term));
    $list = array();        
    foreach($query as $q){
        $data['value']= $q['id'];
        $data['label']= $q['name'];

        $list[]= $data;
        unset($data);
    }

    echo json_encode($list);
}

这是您视图中的搜索表单:

$form=$this->beginWidget('CActiveForm', array(
'id'=>'searchform',
'enableAjaxValidation'=>false,
'action' => '/'
)); ?>

    <fieldset>
        <div class="input-append">
        <?php

        echo CHtml::hiddenField('selectedvalue','');

         $this->widget('zii.widgets.jui.CJuiAutoComplete', array(
            'name'=>'searchbox',
            'value'=>'',
            'source'=>CController::createUrl('/site/autoComplete'),
            'options'=>array(
            'showAnim'=>'fold',         
            'minLength'=>'2',
            'select'=>'js:function( event, ui ) {
                        $("#searchbox").val( ui.item.label );
                        $("#selectedvalue").val( ui.item.value );
                        return false;
                  }',
            ),
            'htmlOptions'=>array(
            'onfocus' => 'js: this.value = null; $("#searchbox").val(null); $("#selectedvalue").val(null);',
            'class' => 'input-xxlarge search-query',
            'placeholder' => "Search...",
            ),
            ));
            echo '<button class="btn" type="submit">Submit</button>';   

        ?>
        </div>
    </fieldset>

<?php $this->endWidget(); ?>    
</form>

答案 1 :(得分:0)

由于这种情况

array('somecolumn'=>$term)

只有在你写完整字符串时它才会显示结果。例如,你有[&#39; coffee&#39;,&#39; cake&#39;]。当您在搜索框中输入时,它不会显示coff,cof,co,ca,cak等的结果。只有在您输入完整的单词咖啡时才显示结果,您将得到[&#39;咖啡&#39;]作为结果。< / p>

所以你需要这样的东西:

$match = $_GET['term'];
$tags = Tags::model()->findAll(
   'tag_name LIKE :match',
   array(':match' => "%$match%")
);

这将显示coff,cof,co,ca,cak等的结果。