首页 > 开发 > PHP > 正文

Thinkphp实现自动验证和自动完成

2024-05-04 22:33:34
字体:
来源:转载
供稿:网友

Thinkphp的自动验证和自动完成都是根所表单提交的内容来的,对部分数据进行规则验证和处理后插入到数据库。

1、自动验证格式:

array(  array(验证字段1,验证规则,错误提示,[验证条件,附加规则,验证时间]),  array(验证字段2,验证规则,错误提示,[验证条件,附加规则,验证时间]),  ......);

验证条件:
self::EXISTS_VALIDATE 或者0 存在字段就验证(默认)
self::MUST_VALIDATE 或者1 必须验证
self::VALUE_VALIDATE或者2 值不为空的时候验证
验证时间:
self::MODEL_INSERT或者1新增数据时候验证
self::MODEL_UPDATE或者2编辑数据时候验证
self::MODEL_BOTH或者3全部情况下验证(默认)

2、自动完成格式:

array(  array(完成字段1,完成规则,[完成条件,附加规则]),  array(完成字段2,完成规则,[完成条件,附加规则]),   ......);

完成时间:
self::MODEL_INSERT或者1   新增数据的时候处理(默认)
self::MODEL_UPDATE或者2   更新数据的时候处理
self::MODEL_BOTH或者3 所有情况都进行处理

小实例(注册)
HTML布局:

<form class="form-horizontal" action="{:U('Login/register')}" method="post" autocomplete="off" enctype="multipart/form-data">  <div class="form-group">    <label class="col-lg-2 control-label">用户名</label>    <div class="col-lg-4">      <input class="form-control" type="text" name="username" />    </div>  </div>  <div class="form-group">    <label class="col-lg-2 control-label">密码</label>    <div class="col-lg-4">      <input class="form-control" type="password" name="password" />    </div>  </div>  <div class="form-group">    <label class="col-lg-2 control-label">重复密码</label>    <div class="col-lg-4">      <input class="form-control" type="password" name="repassword" />    </div>  </div>  <div class="form-group">    <label class="col-lg-2 control-label">头像</label>    <div class="col-lg-4">      <input class="form-control" type="file" name="portrait" id="imgpath" />      <img style="width: 100%;" src="" id="showimgpath" alt="头像"/>      <span class="help-block">关像的大小为80*80px</span>    </div>  </div>  <div class="form-group">    <label class="col-lg-2 control-label">性别</label>    <div class="col-lg-4">      <div class="btn-group" data-toggle="buttons">        <label class="btn btn-default active">          <input type="radio" name="gender" autocomplete="off" value="1" checked /> 男        </label>        <label class="btn btn-default">          <input type="radio" name="gender" autocomplete="off" value="0" /> 女        </label>      </div>    </div>  </div>  <div class="form-group">    <label class="col-lg-2 control-label">电话号码</label>    <div class="col-lg-4">      <input class="form-control" type="input" name="phone" />    </div>  </div>  <div class="form-group">    <label class="col-lg-2 control-label">邮箱</label>    <div class="col-lg-4">      <input class="form-control" type="input" name="email" />    </div>  </div>  <div class="form-group">    <div class="col-lg-2 col-lg-offset-2">      <button class="btn btn-primary btn-block btn-submit" type="submit">注册</button>    </div>  </div></form>            
发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表