2014-02-17 3 views
-3

저는 Yii를 처음 접했고, 내 컨트롤러에서 PHP 변수 값을 전달할 것입니다. 누군가 도움을 청할 수 있습니까? 나는 여기 붙어있다. JavaScript를 사용하여 자동 완성 필드에서이 변수를 계산해야합니다. 미리 감사드립니다.YII의 페이지를보기 위해 PHP 변수 값을 전달합니다.

내 컨트롤러 액션 :

public function actionIndex() 
    { 

      $user = Yii::app()->db->createCommand() 
    ->select('cust_name') 
    ->from('mst_customers') 
    ->queryAll(); 

     $dataProvider=new CActiveDataProvider('model_name'); 

       $this->render('index',array(
      'dataProvider'=>$dataProvider, 



     )); 

    } 

내보기 :

<!--Content--> 

<div id="content"> 
    <div style="padding: 10px;"> 
     <a href="<?php echo $this->createUrl('/controller_name/create');?>" title="Create New Host" class="btn btn-primary circle_ok" style="text-decoration: none;" >Add New Host to Customer</a> 

    <div style="float:right"> 
         <?php 
          echo CHtml::link('Upload Customer CSV', array('/controller_name/uploadCustomers'), array(
          'onclick'=>'return hs.htmlExpand(this, { objectType: "iframe", wrapperClassName: "full-size", align: "center" })', 
          'class'=>'btn btn-primary', 
          'id'=>'upload_link', 
          )); 
         ?>       
        </div> 
    </div> 
    <h3><?php echo htmlspecialchars($title); ?></h3> 
    <h3><?php echo $title; ?></h3> 


    <div class="innerLR"> 
     <div class="row-fluid"> 
<?php 

$obj=$this->widget('zii.widgets.grid.CGridView', array(
    'dataProvider'=>$dataProvider, 


    //'afterAjaxUpdate'=>'\'changeTRColor()\'', 
    //'itemView'=>'_view', 
    'columns'=>array(

       array(   // display 'create_time' using an expression 
          'name'=>'name', 
              'value'=>'$data->host_name', 
       ), 
       array(
          'name'=>'serviceId', 
          'value'=>'$data->host_serviceid', 
       ), 

       array(
              'name'=>'customer', 
              'value'=>'$data->customers->cust_name', 
       ), 
       array(
            'class'=>'CButtonColumn', 
            'template'=>'{delete}{update}',) 



), 
)); 

?> 

     </div> 

<html lang="en"> 
<head> 
    <meta charset="utf-8"> 
    <title>jQuery UI Autocomplete - Default functionality</title> 
    <link rel="stylesheet" href="//code.jquery.com/ui/1.10.4/themes/smoothness/jquery-ui.css"> 
    <script src="//code.jquery.com/jquery-1.9.1.js"></script> 
    <script src="//code.jquery.com/ui/1.10.4/jquery-ui.js"></script> 
    <link rel="stylesheet" href="/resources/demos/style.css"> 
    <script type="text/javascript"> 
//autocomplete 
    $(function() { 
    var availableTags =<?php echo CJSON::encode($user);?>; 

     /*"ActionScript", 
     "AppleScript", 
     "Asp", 
     "BASIC", 
     "C", 
     "C++", 
     "Clojure", 
     "COBOL", 
     "ColdFusion", 
     "Erlang", 
     "Fortran", 
     "Groovy", 
     "Haskell", 
     "Java", 
     "JavaScript", 
     "Lisp", 
     "Perl", 
     "PHP", 
     "Python", 
     "Ruby", 
     "Scala", 
     "Scheme"*/ 

    console.log(availableTags); 
    $("#Search").autocomplete({ 
     source: availableTags 
    }); 
    }); 
    </script> 
</head> 
<body> 

<div class="ui-widget"> 
    <label for="Search">Search Customer: </label> 
    <input id="Search"> 
</div> 


</body> 
</html> 

     <div class="separator bottom"></div> 
    </div> 
</div> 
<!-- // Content END --> 
<div class="clearfix"></div> 
<!-- // Sidebar menu & content wrapper END --> 

<div id="footer" class="hidden-print"> 
<?php $this->renderPartial('application.views.layouts._footer_inc'); ?> 
</div> 
+0

당신이보기 파일에 전달할 무엇을 원하는가? –

답변

1
$this->render('index',array(
     'dataProvider'=>$dataProvider, 
     'user' => $user, 
)); 
+0

내 대답을 모두 받아 들일 수 : D – tinybyte

+0

배열 요소를 얻을 수 있지만 주요 위협은 내가 자바 스크립트를 사용하여 이러한 요소를 자동 완성해야한다는 것입니다. 어떻게해야합니까? – user3107044

+0

키 인덱스를 사용하지 않고 배열을 만들어야한다고 생각합니다. 배열에서'var_dump()'를 사용하면 어떤 배열인지 알게되고, 단지 foreach 루프를 실행하고 키 인덱스없이 새로운 배열을 만듭니다. – tinybyte

관련 문제