摘要:总结:本章主要学习到了模板标签的使用,foreach,volist,和数据分页,文件上传的操作,/*********************** Staff.php 控制器 ***************************/ <?php namespace app\index\controller; use app\mode
总结:本章主要学习到了模板标签的使用,foreach,volist,和数据分页,文件上传的操作,
/*********************** Staff.php 控制器 ***************************/
<?php
namespace app\index\controller;
use app\models\Recruit;
use think\Controller;
use app\index\model\Staff as StaffModel;//设置模型类的别名
class Staff extends Controller
{
//循环标签
public function demo1()
{
$staffs = StaffModel::all(function($query){
$query->field(['staff_id','name','sex','age','salary']);
//->where('salary','<',100);
});
//dump($staffs);die;
//模板赋值
$this->view->assign('staffs',$staffs);
//渲染模板
return $this->view->fetch();
}
//分页
public function demo2()
{
//分页配置
$config = [
'type' => 'bootstrap',
'var_page' => 'page'
];
//每页显示的数量
$num = 5;
//是否是简单分页?就是只是:上一页,下一页
$simple = false;
//用模型来获取所有的分页数据:think\Paginate
$paginate = StaffModel::paginate($num,$simple,$config);
//渲染分页HTML代码,返回分页变量
$page = $paginate->render();
//将分页数据复制给模板
$this->view->assign('staffs',$paginate);
//将分页额变量赋值给模板
$this->view->assign('page',$page);
//渲染模板
return $this->view->fetch();
}
//文件上传
public function demo3()
{
//渲染模板
return $this->view->fetch();
}
//处理文件上传
public function demo4()
{
// 1,获取文件的信息
$file = request()->file('file');
if(is_null($file)){
$this->error('没有选择任何文件');
}
//2,移动文件到服务器上的指定目录:public/uploads
$res = $file->validate(['ext'=>'jpg,jpeg,png'])->move('uploads');
//3,对上传进行验证:文件大小,文件类型
if(false == $res){
$this->error($file->getError());
}
$this->success('上传成功');
}
}/************************* demo2.html 标签使用和翻页 ******************************/
{load href="/static/bootstrap/css/bootstrap.css"}
<div class="container">
<div class="row">
<h3 class="text-center">员工信息登记表</h3>
<div class="col-md-8 col-md-offset-2">
<table class="table table-bordered table-hover text-center">
<tr class="info">
<td>ID</td>
<td>姓名</td>
<td>性别</td>
<td>年龄</td>
<td>工资</td>
</tr>
{volist name="staffs" id="staff"}
<tr>
<td>{$staff.staff_id}</td>
<td>{$staff.name}</td>
<td>
{//$staff.sex}
{//性别必须是0或1,才是合法数据}
{in name="staff.sex" value="0,1"}
{if $staff.sex == 0}
男
{else /}
女
{/if}
{/in}
</td>
<td>
{//$staff.age}
{//between标签}
{between name="staff.age" value="20,30"}
很年轻
{/between}
{between name="staff.age" value="31,50"}
人到中年
{else /}
快退休了
{/between}
</td>
<td>{$staff.salary}</td>
</tr>
{/volist}
</table>
<div class="text-center">{$page|raw}</div>
</div>
</div>
</div>
{load href="/static/jquery/jquery-3.3.1.js"}
{load href="/static/bootstrap/js/bootstrap.js"}
/****************************** demo3.html 文件上传 ******************************/
<h3>文件上传</h3>
<form action="{:url('demo4')}" enctype="multipart/form-data" method="post">
<input type="file" name="file" /> <br>
<input type="submit" value="上传" />
</form>
批改老师:天蓬老师批改时间:2018-11-28 15:19:53
老师总结:文件上传是通过file对象完成,这个对象实际上已经封装好了的, 但并没有提供facade调用模式,要注意
还有,上传文件是一个非常危险的操作,一定要有验证.
另外,在实际开发过程,大多是通过富文本编辑器提供的上传功能,注意这个上传接口的编写,原理与上面是一样的,也是在控制器创建一个方法来处理