我遇到了afterDelete回調方法的問題。我無法使用它們。Cakephp 3未達到回調方法
我的一個「Storages」插件控制器中我想刪除一條記錄,之後我想做一些其他的想法,但回調方法沒有達到。我已經在afterDelete()回調方法中添加了一條日誌消息來檢查。
這是我刪除一條記錄,所述控制器:
namespace Storages\Controller;
class StoragecontainerBlocksController extends AppController {
public function initialize() {
parent::initialize();
$this->loadComponent('RequestHandler');
}
public function ajaxDeleteBlockElement() {
$this->autoRender = false;
// load model
$this->loadModel("StoragecontainerBlockElements");
// get element id
$elementId = $this->request->data('id');
$this->request->allowMethod(['post', 'delete']);
// delete element
$storagecontainerBlockElement = $this->StoragecontainerBlockElements->get($elementId);
$this->StoragecontainerBlockElements->delete($storagecontainerBlockElement);
}
}
這就是afterDelete回調定義(模型)表:
use Cake\Log\Log;
class StoragecontainerBlockElementsTable extends Table {
public function afterDelete(Event $event) {
Log::debug('Got here');
}
}
更新:
當我在ajaxDeleteBlockElement函數內部調試Log::debug($this->StoragecontainerBlockElements);
時,我在debug.log文件中得到了以下數組:
2017-03-31 07:03:48 Debug: Cake\ORM\Table Object
(
[registryAlias] => StoragecontainerBlockElements
[table] => storagecontainer_block_elements
[alias] => StoragecontainerBlockElements
[entityClass] => \Cake\ORM\Entity
[associations] => Array
(
)
[behaviors] => Array
(
)
[defaultConnection] => default
[connectionName] => default
更新:
namespace Storages\Model\Table;
use Cake\ORM\RulesChecker;
use Cake\ORM\Table;
use Cake\Validation\Validator;
use Cake\Log\Log;
class StoragecontainerBlockElementsTable extends Table {
public function initialize(array $config) {
parent::initialize($config);
}
public function afterDelete(Event $event) {
Log::debug('Got here');
}
}
'$這個 - > StoragecontainerBlockElements'可能不是你認爲它是...調試屬性,以確保它不是一個自動錶(一個'\ Cake \ ORM \ Table'的實例)。 – ndm
我用調試結果更新了我的問題。 – CodeWhisperer