【问题标题】:Dependent Dropdown box CakePHP 3依赖下拉框 CakePHP 3
【发布时间】:2023-03-16 16:40:01
【问题描述】:

我创建了一个国家、城市和客户表,我试图确保当我从下拉列表中添加新客户时,我可以选择一个国家,然后选择一个与该国家相关的城市。目前我无法从下拉列表中选择任何城市和国家组合。 这是我的数据库

CREATE TABLE IF NOT EXISTS `southpac_team`.`customers` (
  `id` INT NOT NULL,
  `name` VARCHAR(100) NULL,
  `country_id` INT NULL,
  `city_id` INT NULL,
  `address` VARCHAR(255) NULL,
  `postal_address` VARCHAR(255) NULL,
  `phone` VARCHAR(45) NULL,
  `email` VARCHAR(100) NULL,
  `payment_terms_id` INT NULL,
  `stop_credit` TINYINT(1) NULL,
  `gst_percentage` INT NULL,
  `currency` VARCHAR(45) NULL,
  `account_closed` TINYINT(1) NULL,
  `invoice_email` VARCHAR(100) NULL,
  `customer_notes` VARCHAR(255) NULL,
  PRIMARY KEY (`id`))
ENGINE = InnoDB;

CREATE TABLE IF NOT EXISTS `southpac_team`.`countries` (
  `id` INT NOT NULL AUTO_INCREMENT,
  `name` VARCHAR(100) NULL,
  PRIMARY KEY (`id`))
ENGINE = InnoDB;

CREATE TABLE IF NOT EXISTS `southpac_team`.`cities` (
  `id` INT NOT NULL AUTO_INCREMENT,
  `country_id` INT NOT NULL,
  `name` VARCHAR(100) NULL,
  PRIMARY KEY (`id`))
ENGINE = InnoDB;

我使用 Cake Bake 创建表之间的关系,这是我的客户控制器。

<?php
namespace App\Controller;

use App\Controller\AppController;

/**
 * Customers Controller
 *
 * @property \App\Model\Table\CustomersTable $Customers
 */
class CustomersController extends AppController
{

    /**
     * Index method
     *
     * @return \Cake\Network\Response|null
     */
    public function index()
    {
        $this->paginate = [
            'contain' => ['Countries', 'Cities', 'PaymentTerms']
        ];
        $customers = $this->paginate($this->Customers);

        $this->set(compact('customers'));
        $this->set('_serialize', ['customers']);
    }

    /**
     * View method
     *
     * @param string|null $id Customer id.
     * @return \Cake\Network\Response|null
     * @throws \Cake\Datasource\Exception\RecordNotFoundException When record not found.
     */
    public function view($id = null)
    {
        $customer = $this->Customers->get($id, [
            'contain' => ['Countries', 'Cities', 'PaymentTerms']
        ]);

        $this->set('customer', $customer);
        $this->set('_serialize', ['customer']);
    }

    /**
     * Add method
     *
     * @return \Cake\Network\Response|null Redirects on successful add, renders view otherwise.
     */
    public function add()
    {
        $customer = $this->Customers->newEntity();
        if ($this->request->is('post')) {
            $customer = $this->Customers->patchEntity($customer, $this->request->data);
            if ($this->Customers->save($customer)) {
                $this->Flash->success(__('The customer has been saved.'));

                return $this->redirect(['action' => 'index']);
            }
            $this->Flash->error(__('The customer could not be saved. Please, try again.'));
        }
        $countries = $this->Customers->Countries->find('list', ['limit' => 200]);
        $cities = $this->Customers->Cities->find('list', ['limit' => 200]);
        $paymentTerms = $this->Customers->PaymentTerms->find('list', ['limit' => 200]);
        $this->set(compact('customer', 'countries', 'cities', 'paymentTerms'));
        $this->set('_serialize', ['customer']);
    }

    /**
     * Edit method
     *
     * @param string|null $id Customer id.
     * @return \Cake\Network\Response|null Redirects on successful edit, renders view otherwise.
     * @throws \Cake\Network\Exception\NotFoundException When record not found.
     */
    public function edit($id = null)
    {
        $customer = $this->Customers->get($id, [
            'contain' => []
        ]);
        if ($this->request->is(['patch', 'post', 'put'])) {
            $customer = $this->Customers->patchEntity($customer, $this->request->data);
            if ($this->Customers->save($customer)) {
                $this->Flash->success(__('The customer has been saved.'));

                return $this->redirect(['action' => 'index']);
            }
            $this->Flash->error(__('The customer could not be saved. Please, try again.'));
        }
        $countries = $this->Customers->Countries->find('list', ['limit' => 200]);
        $cities = $this->Customers->Cities->find('list', ['limit' => 200]);
        $paymentTerms = $this->Customers->PaymentTerms->find('list', ['limit' => 200]);
        $this->set(compact('customer', 'countries', 'cities', 'paymentTerms'));
        $this->set('_serialize', ['customer']);
    }

    /**
     * Delete method
     *
     * @param string|null $id Customer id.
     * @return \Cake\Network\Response|null Redirects to index.
     * @throws \Cake\Datasource\Exception\RecordNotFoundException When record not found.
     */
    public function delete($id = null)
    {
        $this->request->allowMethod(['post', 'delete']);
        $customer = $this->Customers->get($id);
        if ($this->Customers->delete($customer)) {
            $this->Flash->success(__('The customer has been deleted.'));
        } else {
            $this->Flash->error(__('The customer could not be deleted. Please, try again.'));
        }

        return $this->redirect(['action' => 'index']);
    }
}

这是我的客户 add.ctp

<?php
/**
  * @var \App\View\AppView $this
  */
?>
<nav class="large-3 medium-4 columns" id="actions-sidebar">
    <ul class="side-nav">
        <li class="heading"><?= __('Actions') ?></li>
        <li><?= $this->Html->link(__('List Customers'), ['action' => 'index']) ?></li>
        <li><?= $this->Html->link(__('List Countries'), ['controller' => 'Countries', 'action' => 'index']) ?></li>
        <li><?= $this->Html->link(__('New Country'), ['controller' => 'Countries', 'action' => 'add']) ?></li>
        <li><?= $this->Html->link(__('List Cities'), ['controller' => 'Cities', 'action' => 'index']) ?></li>
        <li><?= $this->Html->link(__('New City'), ['controller' => 'Cities', 'action' => 'add']) ?></li>
        <li><?= $this->Html->link(__('List Payment Terms'), ['controller' => 'PaymentTerms', 'action' => 'index']) ?></li>
        <li><?= $this->Html->link(__('New Payment Term'), ['controller' => 'PaymentTerms', 'action' => 'add']) ?></li>
    </ul>
</nav>
<div class="customers form large-9 medium-8 columns content">
    <?= $this->Form->create($customer) ?>
    <fieldset>
        <legend><?= __('Add Customer') ?></legend>
        <?php
            echo $this->Form->input('name');
            echo $this->Form->input('country_id', ['options' => $countries, 'empty' => true]);
            echo $this->Form->input('city_id', ['options' => $cities, 'empty' => true]);
            echo $this->Form->input('address');
            echo $this->Form->input('postal_address');
            echo $this->Form->input('phone');
            echo $this->Form->input('email');
            echo $this->Form->input('payment_terms_id', ['options' => $paymentTerms, 'empty' => true]);
            echo $this->Form->input('stop_credit');
            echo $this->Form->input('gst_percentage');
            echo $this->Form->input('currency');
            echo $this->Form->input('account_closed');
            echo $this->Form->input('invoice_email');
            echo $this->Form->input('customer_notes');
        ?>
    </fieldset>
    <?= $this->Form->button(__('Submit')) ?>
    <?= $this->Form->end() ?>
</div>

我能够创建新客户并选择国家和引用我只想限制投递箱,以便我只能为正确的国家/地区选择一个城市。我试图对此进行研究,但刚刚遇到了使用 jshelper 的示例,其中 cakephp 3.0 不包括在内。 谢谢。

【问题讨论】:

标签: php mysql cakephp cakephp-3.0


【解决方案1】:

你可以试试 jQuery 的链式选择插件 Chained Selects Plugin for jQuery and Zepto

所需的源文件:

ajax.googleapis.com/ajax/libs/jquery/1.10.2/jquery.min.js
jquery.chained.min.js

例子:

$(document).ready(function() { 
    $("#cityId").chained("#countryId");
});

【讨论】:

  • 我试过这个,但我无法让链式插件工作,但我可以使用 JQuery 获得弹出消息。我也尝试按照示例进行操作,但它似乎不起作用。
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 2023-04-06
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2017-08-02
  • 1970-01-01
相关资源
最近更新 更多