前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >复制某一条数据记录并新建

复制某一条数据记录并新建

作者头像
正经人
发布2023-08-09 14:40:46
2450
发布2023-08-09 14:40:46
举报
文章被收录于专栏:正经人正经人

当我们添加一些数据的时候,有些数据很多列都是重复的,只有一、两列才会有变动,如果用导入导出的功能又太麻烦,因为数据可能就几条,所以很多软件都会有复制新建功能

在fastadmin里面添加复制新建功能需要如下修改

1.新建copy.html

把edit.html复制一份改成copy.html,放在view下面

2.修改控制器

在对应的控制器中新增copy的function

构建copy的function也比较简单,直接从application/admin/library/traits/Backend.php里面把add和edit取一下就可以了

edit取上半部分

add取下半部分

就变成了下面这样

代码语言:javascript
复制
/**
     * 复制
     *
     * @param $ids
     * @return string
     * @throws DbException
     * @throws \think\Exception
     */
    public function copy($ids = null)
    {
        $row = $this->model->get($ids);
        if (!$row) {
            $this->error(__('No Results were found'));
        }
        $adminIds = $this->getDataLimitAdminIds();
        if (is_array($adminIds) && !in_array($row[$this->dataLimitField], $adminIds)) {
            $this->error(__('You have no permission'));
        }
        if (false === $this->request->isPost()) {
            $this->view->assign('row', $row);
            return $this->view->fetch();
        }
        $params = $this->request->post('row/a');
        if (empty($params)) {
            $this->error(__('Parameter %s can not be empty', ''));
        }
        $params = $this->preExcludeFields($params);

        if ($this->dataLimit && $this->dataLimitFieldAutoFill) {
            $params[$this->dataLimitField] = $this->auth->id;
        }
        $result = false;
        Db::startTrans();
        try {
            //是否采用模型验证
            if ($this->modelValidate) {
                $name = str_replace("\\model\\", "\\validate\\", get_class($this->model));
                $validate = is_bool($this->modelValidate) ? ($this->modelSceneValidate ? $name . '.add' : $name) : $this->modelValidate;
                $this->model->validateFailException()->validate($validate);
            }
            $result = $this->model->allowField(true)->save($params);
            Db::commit();
        } catch (ValidateException|PDOException|Exception $e) {
            Db::rollback();
            $this->error($e->getMessage());
        }
        if ($result === false) {
            $this->error(__('No rows were inserted'));
        }
        $this->success();
    }

3.修改js文件

找到对应的js文件,在操作栏增加一个复制新建按钮

也加一下copy页面的表单初始化操作

刷新页面就有复制新建按钮,点击后弹出一个新窗口,在新窗口里面修改一下数据,点击确定即可添加成功

本文系转载,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文系转载前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档