首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >CakePHP-2.4 :按ajax分类的子分类

CakePHP-2.4 :按ajax分类的子分类
EN

Stack Overflow用户
提问于 2014-11-05 14:05:24
回答 1查看 746关注 0票数 0

我正在尝试通过ajax.So来根据类别得到子类别,我已经通过ajax get方法在控制器中发送了数据,就像add.ctp中的以下代码

代码语言:javascript
复制
$('document').ready(function(){
            $( "#division" ).change(function() {

                        var value=$('#division').val(); 

                            $.get("<?php echo   Router::url(array('controller'=>'userStoreSelections','action'=>'add'));?>",{list:value},function(data){
                    $('.districts').html(data);
                    alert(data);
                });
            });
    });

在find方法的控制器中,当我编写下面的代码时,它工作得很好。

代码语言:javascript
复制
$madDistricts = $this->UserStoreSelection->MadDistricts->find('list',array(
            'conditions'=>array('mad_divisions_id'=>3)
));

但是当我给出我通过ajax发送的值时,它不起作用。

代码语言:javascript
复制
$madDistricts = $this->UserStoreSelection->MadDistricts->find('list',array(
            'conditions'=>array('mad_divisions_id'=>"$list")
));

它显示的查询如下

代码语言:javascript
复制
SELECT `MadDistricts`.`id`, `MadDistricts`.`name` FROM `store`.`mad_districts` AS `MadDistricts` WHERE `mad_divisions_id` IS NULL       

选择类别后,查询没有任何变化。我已经测试了ajax代码,发送值没有问题。

更具体地说,这是添加操作代码

代码语言:javascript
复制
public function add() {

        if(isset($this->request->query['list'])){
            $search = $this->request->query['list'];
            echo $search;
        }
        else{
            $search = '';
        }
        if ($this->request->is('post')) {
            $this->UserStoreSelection->create();
            if ($this->UserStoreSelection->save($this->request->data)) {
                $this->Session->setFlash(__('The user store selection has been saved.'));
                return $this->redirect(array('action' => 'index'));
            } else {
                $this->Session->setFlash(__('The user store selection could not be saved. Please, try again.'));
            }
        }
        $madDivisions = $this->UserStoreSelection->MadDivisions->find('list');

            $madDistricts = $this->UserStoreSelection->MadDistricts->find('list',array(
            'conditions'=>array('mad_divisions_id'=>"$list")
         ));
        $madAreas = $this->UserStoreSelection->MadAreas->find('list');
        $users = $this->UserStoreSelection->Users->find('list',array('fields' => array('id','username')));
        $madStores = $this->UserStoreSelection->MadStores->find('list',array('fields' => array('id','store_name')));
        $this->set(compact('madDivisions', 'madDistricts', 'madAreas', 'users','madStores'));
    } 
EN

回答 1

Stack Overflow用户

发布于 2014-11-05 15:51:28

您需要更改add.ctp文件代码,如下所示:

代码语言:javascript
复制
$('document').ready(function () {
$("#division").change(function () {
    var value = $(this).val();
    $.ajax({
        url: '<?php echo Router::url(' / ',true);?>userStoreSelections/subcategories',
        type: "POST",
        dataType: 'json',
        data: 'category=' + id,
        success: function (res) {
            var html = '<option>Sub Category</option>';
            if (res.flage == true) {
                 html = res.data;
            }
            $('.districts').html(html);
        }
    });
});

});

然后在userStoreSelections中为Get子类别创建一个函数,如下所示

代码语言:javascript
复制
public function subcategories() {

    $response = array('flage' => false);

    $madDistricts = $this->UserStoreSelection->MadDistricts->find('list', array(
        'conditions' => array('mad_divisions_id' => $this->request->data['category'])
    ));

    $options = "<option>Subcategories</option>";
    if ($states) {
        $response['flage'] = true;
        foreach ($madDistricts as $id => $name) {
            $options .= "<option value='" . $id . "'>" . $name . "</option>";
        }
        $response['data'] = $options;
    }
    echo json_encode($response);
    exit;
}
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/26750706

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档