6

任务:当我从选择标签客户(我有客户ID)中选择时,它必须将请求输入数据库并返回所有客户字段。然后它必须自动填充一些输入。我尝试制作 ajax+jQuery。阿贾克斯不错。它现在正在工作!

这是JS:

我想通了:

<script>
$(document).ready(function() {
    $('#customer_load').change(function() {
        $.ajax({
            url: '<?= $this->url(array('action' => 'ajax', 'controller' => 'baza')) ?>',
            type: 'POST',
            dataType: 'json',
            data: {
                    // list of request parameters 
                    'customer_id':  $(this).attr('value')
            },
            success: function(data) {
                    //alert(data.current_discount);
                    $('#extra_discount').val(data.extra_discount);
                    $('#current_discount').val(data.current_discount);
                    $('#customer_number').val(data.customer_id);
            }
        });
    });
});

PHP 初始化:

$this->_helper->AjaxContext()->addActionContext('add', 'json')->initContext('json');

阿贾克斯动作:

$id= $this->_getParam('customer_id');
$result = $this->_customers->fetchSelected($id);
$this->view->customers = $result;
$this->_helper->json($result);

html:

<select name="customer_id" id="customer_load" style="width:300px;">
   <option value="0">Выберите заказчика</option>
      ?php foreach ($this->customers as $cus): ?>
   <option value="<?= $cus['customer_id'] ?>"" <?php if ($cus['customer_id'] == $this->form_data['customer_id']) echo "selected"; ?> ><?= $cus['lastname'] . " " . $cus['name'] ?></option>
   <?php endforeach; ?>
    <option value="new" onclick="NewCustomer()">Новый заказчик</option>
    </select>
4

1 回答 1

1

从您的帖子很难理解问题是在客户端还是服务器端......在您的第一个示例中,您没有customer_id在 ajax 请求中使用,并且您不需要将值转换Number为 javascript。

在下面使用 AJAX 请求:

$(document).ready(function(){
   $.ajax({
     url: <?= $this->url(array('action' => 'add', 'controller' => 'baza')) ?>,
     type: 'POST',
     dataType: 'json',
     data: {
        // list of request parameters 
        'customer_id': $('select[name=customer_id] option:selected').val(),
     },
     success: function(results){
         // analyze your response and add custom logic
         console.debug(result);
     }
   });
});

根据您的 PHP 代码,您将事情复杂化了。在操作顶部添加您的检查并在您尝试使其工作时将它们注释掉(这样您可以baza/add直接在浏览器中测试),一旦您得到它的工作取消注释和测试。使用JSON 视图助手输出 json。

   public function addAction() 
   {
        // checks/validation/etc

        // do some processing...               
        $result = $this->_customers->fetchSelected($id);

        // Send the JSON response:
        $this->_helper->json($result);
   }
于 2012-12-24T16:49:31.330 回答