[thinkPHP5项目实战_10]栏目列表输出和删除

上一篇分享了如何添加栏目和验证。

1.栏目列表输出

添加栏目后需要将其从数据库中取出展示在列表上,比如数据库的tp5_cate有以下数据:


在Cate控制器的lists方法中读取数据数据并赋值给模板

    public function lists()
    {
        // 使用查询构造器查询数据cate表中的所有数据赋给$cateres
        $cateres = \think\Db::name('cate')->select();
        //模板赋值,将$cateres的值赋给模板cateres
        $this->assign('cateres',$cateres);
        return $this->fetch();
    }

在模板将list方法赋值循环输出出来

volist标签通常用于查询数据集(select方法)的结果输出,通常模型的select方法返回的结果是一个二维数组,可以直接使用volist标签进行输出。

使用if条件判断来展示不同的对应的模板数据:

                    <table class="table table-striped">
                        <thead>
                            <tr>
                                <th>ID</th>
                                <th>栏目名称</th>
                                <th>栏目类型</th>
                                <th>操作</th>
                            </tr>
                        </thead>
                        <tbody>
                            <!-- 使用循环输出标签将模板cateres中的数据输出到模板上 -->
                            {volist name="cateres" id="vo"}
                            <tr>
                                <td>{$vo.ID}</td>
                                <td><a href="#" title="{$vo.catename}">{$vo.catename}</a></td>
                                <!-- 使用if条件判断标签对输出的模板数据判断后输出 -->
                                <td>
                                    {if condition="$vo.type neq 0"}列表
                                    {else /} 留言板
                                    {/if}
                                </td>
                                <td>
                                    <a href="">修改</a>
                                    <a href="">删除</a>
                                </td>
                            </tr>
                            {/volist}
                        </tbody>
                    </table>

2.删除栏目

用到了tp5的数据库删除操作

点击删除按钮跳转到当前控制器的del操作方法,并将当前栏目的id传过去,助手函数url是以数组方式传值:

<!-- 删除栏目,使用助手函数url调用当前控制器的del方法,将当前栏目的ID赋给参数id传到控制器中 -->
<!-- 点击删除给一个弹窗判断 -->
<a href="{:url('del',array('id'=>$vo.ID))}" οnclick="return confirm('确定删除该栏目?')">删除</a>

tp5_cate表中定义了主键ID,可以用tp5助手函数进行数据库删除操作:

    public function del()
    {
        //获取模板传过来的id
        $id=input('id');
        //使用助手函数进行删除操作和判断
        if(db('cate')->delete($id)){
            return $this->success('删除栏目成功','lists');
        }else{
            return $this->error('删除栏目失败');
        }
    }

3.效果







评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值