table) : (is_string($dbQuery) ? Db::name($dbQuery) : $dbQuery); $pk = empty($pkField) ? ($db->getPk() ? $db->getPk() : 'id') : $pkField; $pkValue = $this->request->request($pk, isset($where[$pk]) ? $where[$pk] : (isset($extendData[$pk]) ? $extendData[$pk] : null)); // 非POST请求, 获取数据并显示表单页面 if (!$this->request->isPost()) { $vo = ($pkValue !== null) ? array_merge((array)$db->where($pk, $pkValue)->where($where)->find(), $extendData) : $extendData; if (false !== $this->_callback('_form_filter', $vo)) { empty($this->title) || $this->assign('title', $this->title); return $this->fetch($tplFile, ['vo' => $vo]); } return $vo; } // POST请求, 数据自动存库 $data = array_merge($this->request->post(), $extendData); if (false !== $this->_callback('_form_filter', $data)) { $result = DataService::save($db, $data, $pk, $where); if (false !== $this->_callback('_form_result', $result)) { $result !== false ? $this->success('恭喜, 数据保存成功!', '') : $this->error('数据保存失败, 请稍候再试!'); } } } /** * 列表集成处理方法 * @param Query $dbQuery 数据库查询对象 * @param bool $isPage 是启用分页 * @param bool $isDisplay 是否直接输出显示 * @param bool $total 总记录数 * @return array|string */ protected function _list($dbQuery = null, $isPage = true, $isDisplay = true, $total = false) { $db = is_null($dbQuery) ? Db::name($this->table) : (is_string($dbQuery) ? Db::name($dbQuery) : $dbQuery); // 列表排序默认处理 if ($this->request->isPost() && $this->request->post('action') === 'resort') { $data = $this->request->post(); unset($data['action']); foreach ($data as $key => &$value) { if (false === $db->where('id', intval(ltrim($key, '_')))->setField('sort', $value)) { $this->error('列表排序失败, 请稍候再试'); } } $this->success('列表排序成功, 正在刷新列表', ''); } // 列表数据查询与显示 if (null === $db->getOptions('order')) { $fields = $db->getTableFields($db->getTable()); in_array('sort', $fields) && $db->order('sort asc'); } $result = []; if ($isPage) { $rowPage = intval($this->request->get('rows', cookie('rows'))); cookie('rows', $rowPage >= 10 ? $rowPage : 20); $page = $db->paginate($rowPage, $total, ['query' => $this->request->get()]); $result['list'] = $page->all(); $result['page'] = preg_replace(['|href="(.*?)"|', '|pagination|'], ['data-open="$1" href="javascript:void(0);"', 'pagination pull-right'], $page->render()); } else { $result['list'] = $db->select(); } if (false !== $this->_callback('_data_filter', $result['list']) && $isDisplay) { !empty($this->title) && $this->assign('title', $this->title); return $this->fetch('', $result); } return $result; } /** * 当前对象回调成员方法 * @param string $method * @param array|bool $data * @return bool */ protected function _callback($method, &$data) { foreach ([$method, "_" . $this->request->action() . "{$method}"] as $_method) { if (method_exists($this, $_method) && false === $this->$_method($data)) { return false; } } return true; } }