thinkphp5的不同数据添加的规则

jacklove
发布: 2018-06-15 11:16:10
原创
2293人浏览过

在admin系统管理员对数据表添加中,由于不同的数据会有不同的添加方式,不同的数据还有不同的数据库存储类型,下面是常见几种不同类型的数据添加规则//未注明的数据库存储的数据类型均为char

1. 简单文本类添加(姓名、年龄、名称、简介等)

add.html代码段

<p class="col-sm-6">
                                <input class="form-control" id="username" placeholder="" name="username"  type="text">
                            </p>
登录后复制

Admin.php函数部分

 public function add()
    {   
        if(request()->isPost()){            $data=[//将输入的值赋值给数组
                'username'=>input('username'),                'password'=>input('password'),
            ];            $validate = \think\Loader::validate('Admin');//验证环节
            if(!$validate->scene('add')->check($data)){               $this->error($validate->getError()); die;//未通过验证则输出错误
            }            if(db('admin')->insert($data)){//添加数据库
                return $this->success('添加管理员成功!','lst');
            }else{                return $this->error('添加管理员失败!');
            }            return;
        }        return $this->fetch();
    }
登录后复制

在validate文件夹中的Admin.php
文件

<?phpnamespace app\admin\validate;use think\Validate;class Admin extends Validate{
    protected $rule = [//验证条件
        'username'  =>  'require|max:25|unique:admin',        'password' =>  'require',
    ];    protected $message  =   [//报错信息
        'username.require' => '管理员名称必须填写',        'username.max' => '管理员名称长度不得大于25位',        'username.unique' => '管理员名称不得重复',        'password.require' => '管理员密码必须填写',
    ];    protected $scene = [        'add'  =>  ['username'=>'require|unique:admin','password'],        'edit'  =>  ['username'=>'require|unique:admin'],
    ];//约束条件所作用的函数域}
登录后复制

添加效果图

这里写图片描述

这里写图片描述

2.长文本编辑添加(文章、序言、简介等)


长文本通常指的是文章,简介之类需要进行格式修改的文本,在这里可以引用一些插件,项目引用的是百度编辑器,将下载好的百度编辑器文件放在public/static/admin之中
如下图
这里写图片描述

下面是引用该编辑器的方法

这里写图片描述

add.html所在的代码样式

 <p class="col-sm-6">
                                 <label >
                                    <textarea name="content"  id="content" ></textarea>
                                 </label>
                            </p>
登录后复制

在控制器中的函数读取与短文本的方式一样,因为都是char类型
这里写图片描述

完成效果图
这里写图片描述

立即学习PHP免费学习笔记(深入)”;

3.0-1选择添加(性别,yes/no的添加)


 这里使用的是beyond.js里面的插件
 如图
这里写图片描述

源码为

 <p class="form-group">
                            <label for="username" class="col-sm-2 control-label no-padding-right">状态</label>
                            <p class="col-sm-6">
                                <select name="gender">
                                   <option value="请选择状态">请选择状态</option>

                                    <option value="已审核">已审核</option>
                                    <option value="未审核">未审核</option>


                                </select>
                            </p>
                        </p>

                         <p class="form-group">
                            <label for="username" class="col-sm-2 control-label no-padding-right">性别</label>
                                <p class="col-sm-6">
                                 <p class="control-group">
                                                <p class="radio">
                                                    <label>
                                                        <input name="form-field-radio" type="radio" class="colored-blue" value="男">
                                                        <span class="text" >男</span>
                                                    </label>
                                                </p>

                                                <p class="radio">
                                                    <label>
                                                        <input name="form-field-radio" type="radio" class="colored-danger"  value="女">
                                                        <span class="text"> 女</span>
                                                    </label>
                                                </p>

                                                <p class="radio">
                                                    <label>
                                                        <input name="form-field-radio" type="radio" class="colored-success"  value="未确定">
                                                        <span class="text"> 未确定</span>
                                                    </label>
                                                </p>


                                            </p>
                                 </p>
                        </p>
登录后复制

这种性别推荐类最好使用char类型,如果使用整型字符有点麻烦,这种静态提供选项类别,还有一种分类的类别由数据库读入
如下
这里写图片描述

html中代码如下

  <p class="form-group">
                            <label for="group_id" class="col-sm-2 control-label no-padding-right">所属栏目</label>
                            <p class="col-sm-6">
                                <select name="cateid">
                                    <option value="">请选择栏目</option>
                                    {volist name="cateres" id="vo"}                                    <option value="{$vo.id}">{$vo.catename}</option>
                                    {/volist}                                </select>
                            </p>
                            <p class="help-block col-sm-4 red">* 必填</p>
                        </p>
登录后复制

cates来源Article.php中
如下图
这里写图片描述
由于在Article控制器中在modle默认已经连接artcle数据表,但推荐来自其他数据表则在model/Article.php之中利用belongsTo()函数如图所示建立一对多连接(一个页面连接多个数据表,自己的理解,好像不太对)如下图
这里写图片描述
这样一个多选的类型就搞好了

4.日期添加(手动添加与自动添加)


 日期添加一般数据库对应的日期类型为
这里写图片描述

最简单的就是自动添加
 不需要有输入框,这种添加一般为系统固定时间,或者获取当前时间,在控制器之中只需要利用函数或者自定义时间,例如使用date(“Y-m-d H:i:s”);获取当前时间

手动添加时间为在输入框内自己输入当前时间
需要日期模板插件,例如  layui之中的日期插件
这里写图片描述

这里写图片描述

由于需要导入css js等,这里就不说明了,以后有用到时,我会专门对此进行说明

5.图片添加


 首先是数据库里面图片的类型
这里写图片描述

add.html中的代码

 <p class="form-group">
                            <label for="group_id" class="col-sm-2 control-label no-padding-right">缩略图</label>
                            <p class="col-sm-6">
                                <input id="pic" placeholder="" name="pic"  type="file">
                            </p>
                        </p>
登录后复制

下图为控制器代码,其中有比较详细的注释(自己的理解)
这里写图片描述

6.手机号、邮箱添加


 此处和添加短文本一样,主要是对输入的信息判断是否为手机号或邮箱
 在validate/Article.php中
 添加如手册中类似的验证信息进行验证
这里写图片描述

本文讲解了thinkphp5的不同数据添加的规则,更多相关内容请关注php中文网。

相关推荐:

关于ThinkPHP5数据库的相关操作

关于ThinkPHP5的数据库和模型用法

关于thinkphp5.0数据库操作的案例

以上就是thinkphp5的不同数据添加的规则的详细内容,更多请关注php中文网其它相关文章!

PHP速学教程(入门到精通)
PHP速学教程(入门到精通)

PHP怎么学习?PHP怎么入门?PHP在哪学?PHP怎么学才快?不用担心,这里为大家提供了PHP速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号