tp3后台栏目的增删改查

模型

<?php
namespace Admin\Model;
use Think\Model;
class CategoryModel extends Model {

   protected $_validate = array(
      array('cate_name','require','栏目名称必填!',1,regex,3), //默认情况下用正则进行验证
   );
    
   public function catetree(){
      $data=$this->select();


      return $this->resort($data);
   
   }
   
   public function resort($data,$parentid=0,$level=0){
      static $ret=array();
      foreach($data as $k=>$v){
         if($v['parentid']==$parentid){
            $v['level']=$level;
            $ret[]=$v;
            $this->resort($data,$v['cate_id'],$level+1);
         }
      }
      
      return $ret;
   
   }

}

 

控制器

public function add(){
   $cate=D('category');
   if(IS_POST){
      $data['cate_name']=I('cate_name');
      $data['cate_ename']=I('cate_ename');
      $data['parentid']=I('parentid');

      if($cate->create($data)){
               if($cate->add()){
                   $this->success('栏目新增成功',U('lst'));
               }else{
                   $this->error('栏目新增失败!');
               }
      }else{
         $this->error($cate->getError());
      }
      
   
      return;
   }

   $cateres=$cate->catetree();
       $this->assign('cateres',$cateres);
       $this->display();
   }

视图

<form method="post" action="" enctype="multipart/form-data">
   <table class="tbl" width="100%" border="0" cellpadding="0" cellspacing="1" bgcolor="#a8c7ce" οnmοuseοver="changeto()"  οnmοuseοut="changeback()">

     <tr>
       <td height="20" bgcolor="#FFFFFF" class="STYLE6" align="right">栏目名称</td>
       <td height="20" bgcolor="#FFFFFF" class="STYLE19" align="left"><input name="cate_name" type="text" /></td>
</tr>
   
   <tr>
       <td height="20" bgcolor="#FFFFFF" class="STYLE6" align="right">英文名称</td>
       <td height="20" bgcolor="#FFFFFF" class="STYLE19" align="left"><input name="cate_ename" type="text" /></td>
</tr>

   <tr>
       <td height="20" bgcolor="#FFFFFF" class="STYLE6" align="right">上级栏目</td>
       <td class="cd" height="20" bgcolor="#FFFFFF" class="STYLE19" align="left">
       <select name="parentid">
       <option value="0">顶级栏目</option>
       <volist name="cateres" id="vo">
           <option value="{$vo.cate_id}"><?php echo str_repeat('-',$vo[level]*8);?>{$vo.cate_name}</option>
       </volist>
       </select>
       
       </td>
</tr>

   <tr>
       <td height="20" colspan="2" bgcolor="#FFFFFF" class="STYLE6" align="center"><input type="submit" value="确定添加" /></td>
       
</tr>
   </table>
   </form>

 

控制器

public function del($cate_id){
   $cate=D('category');
   if($cate->delete($cate_id)){
      $this->success('删除栏目成功!',U('lst'));
   }else{
      $this->error('删除栏目失败!');
   }

}

视图

<a href="__CONTROLLER__/del/cate_id/{$vo.cate_id}" οnclick="return confirm('您确定要删除该栏目吗?');">删除</a>

 

控制器

public function edit($cate_id){
   $cate=D('category');
   
   if(IS_POST){
      $data['cate_id']=I('cate_id');
      $data['cate_name']=I('cate_name');
      $data['cate_ename']=I('cate_ename');

      $data['parentid']=I('parentid');

      if($cate->create($data)){
      if($cate->save()){
         $this->success('栏目修改成功',U('lst'));
      }else{
         $this->error('栏目修改失败!');
      }
      }else{
         $this->error($cate->getError());
      }
      
   
      return;
   }
   
   $cateresa=$cate->find($cate_id);
   $this->assign('cateresa',$cateresa);


   $cateres=$cate->catetree();
   $this->assign('cateres',$cateres);
       $this->display();
   }

视图

<form method="post" action="" enctype="multipart/form-data">
   <input type="hidden" name="cate_id" value="{$cateresa.cate_id}" />
   <table class="tbl" width="100%" border="0" cellpadding="0" cellspacing="1" bgcolor="#a8c7ce" οnmοuseοver="changeto()"  οnmοuseοut="changeback()">

     <tr>
       <td height="20" bgcolor="#FFFFFF" class="STYLE6" align="right">栏目名称</td>
       <td height="20" bgcolor="#FFFFFF" class="STYLE19" align="left"><input name="cate_name" type="text" value="{$cateresa.cate_name}" /></td>
</tr>
   
   <tr>
       <td height="20" bgcolor="#FFFFFF" class="STYLE6" align="right">英文名称</td>
       <td height="20" bgcolor="#FFFFFF" class="STYLE19" align="left"><input name="cate_ename" type="text" value="{$cateresa.cate_ename}" /></td>
</tr>
   
    <tr>
       <td height="20" bgcolor="#FFFFFF" class="STYLE6" align="right">上级栏目</td>
       <td class="cd" height="20" bgcolor="#FFFFFF" class="STYLE19" align="left">
       <select name="parentid">
       <option value="0">顶级栏目</option>
       <volist name="cateres" id="vo">
       <option <if condition="$cateresa[cate_id] eq $vo[cate_id]">style="display:none;"</if>  <if condition="$cateresa[parentid] eq $vo[cate_id]"> selected="selected"</if>  value="{$vo.cate_id}"><?php echo str_repeat('-',$vo[level]*8);?>{$vo.cate_name}</option>
       </volist>
       </select>
       
       </td>
</tr>

   <tr>
       <td height="20" colspan="2" bgcolor="#FFFFFF" class="STYLE6" align="center"><input type="submit" value="确定修改" /></td>
       
</tr>
   </table>
   </form>

控制器

public function lst(){
   $cate=D('category');
   $cateres=$cate->catetree();
   $this->assign('cateres',$cateres);
       $this->display();
   }

视图

<volist name="cateres" id="vo">
  <tr>
    <td height="20" bgcolor="#FFFFFF"><div align="center">
      <input type="checkbox" class="selall" name="bdel[]" value="{$vo.cate_id}" />
    </div></td>
    <td height="20" bgcolor="#FFFFFF" class="STYLE6"><div align="center"><span class="STYLE19">{$vo.cate_id}</span></div></td>
    <td height="20" bgcolor="#FFFFFF" class="STYLE19" align="left" style="padding-left:5px;"><?php echo str_repeat('-',$vo[level]*8);?>{$vo.cate_name}</td>

    <td height="20" bgcolor="#FFFFFF" class="STYLE19"><div align="center">{$vo.parentid}</div></td>
    <td height="20" bgcolor="#FFFFFF"><div align="center" class="STYLE21"><a href="__CONTROLLER__/edit/cate_id/{$vo.cate_id}">修改</a> | <a href="__CONTROLLER__/del/cate_id/{$vo.cate_id}" οnclick="return confirm('您确定要删除该栏目吗?');">删除</a></div></td>
  </tr>
  </volist>

 

 

 

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
引用\[1\]:LayTab类是一个用于将数据转换成layui需要的数据形式的工具类。它包含了一些属性和方法,用于设置数据的格式和内容。\[1\]引用\[2\]:在具体功能的实现中,页面主要是对所有的信息进行查询,并将其显示出来。利用layui的数据表格来将数据显示在前端的页面上。首先需要在自己的jsp页面上复制layui官网上提供的数据表格代码,并进行相应的修改。\[2\]引用\[3\]:页面主要实现了查询所有、添加书籍、修改书籍、删除书籍、书籍的上下架和模糊搜索等功能。具体流程如下:首先查询数据库中的数据表信息,并将其显示在页面中;然后通过点击添加按钮,弹出层显示添加书籍的表单;接着通过点击修改按钮,弹出层显示修改书籍的表单;再通过点击删除按钮,删除书籍;还可以对书籍进行上下架操作;最后可以进行模糊搜索。\[3\] 根据你的问题,TP5+layui增删改查的实现可以参考以下步骤: 1. 首先需要在TP5中配置数据库连接和相关的模型(Model)。 2. 在控制器(Controller)中编写相应的方法,用于处理增删改查的请求。 3. 在视图(View)中使用layui的数据表格来显示数据,并添加相应的按钮和表单。 4. 在前端页面中,通过ajax请求将数据发送到后端进行处理,并将结果显示在页面上。 5. 根据需要,可以使用TP5的验证器(Validator)来对用户输入的数据进行验证。 6. 在控制器中根据请求的类型(增删改查)来执行相应的操作,并返回相应的结果。 通过以上步骤,你可以实现TP5+layui的增删改查功能。具体的代码实现可以根据你的需求进行相应的调整和修改。 #### 引用[.reference_title] - *1* *2* *3* [layui实现增删改查——图书管理](https://blog.csdn.net/weixin_42381196/article/details/118058698)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值