php上下箭头排序

 

点击向上的箭头时候,排序顺序会与上面的交换。点击向下的箭头时候会与下面的排序交换。当排在第一个时候点击向上箭头提示已经是第一个,当排在最后一个时候点击向下箭头,提示已经是最后一个,

<td>{$imginfo.wedd_order}
                        <if condition="$imginfo.wedd_order neq 0">
                        <a href="{:U('Img/weddorderdown',array('id'=>$imginfo['id'],'wedd_order'=>$imginfo['wedd_order']))}" style="padding: 4px;">&#8595; </a>
                        <a href="{:U('Img/weddorderup',array('id'=>$imginfo['id'],'wedd_order'=>$imginfo['wedd_order']))}" style="padding: 4px;">&#8593;</a>
                        </if>
                    </td>

//向上排序

        public function weddorderup(){
            //得到该数据当前的id和顺序
            $id=I('get.id');
            $where['id']=$id;
            $wedd_order=I('get.wedd_order');
            if($wedd_order==1){
                $this->error('当前排序已经是第一个');
            }
            //根据id获取整条数据
            $img=M('img');
            $currinfo=$img->where($where)->find();
            
            //print_r($currinfo);
            //判断是否为子分类,若为子分类,则查出pid相同的数据,若不为只分类,则查出wedd_pos相同的数据
            if($currinfo['pid']==0){
                $weddpos=$currinfo['wedd_pos'];
                $classify['wedd_pos']=$weddpos;
                $classify['wedd_order']=array('lt',$wedd_order);
                $twoinfo=$img->where($classify)->order('wedd_order desc')->find();
                
                $updw['id']=$currinfo['id'];
                $data['wedd_order']=$wedd_order-1;
                
                $twow['id']=$twoinfo['id'];
                $twodata['wedd_order']=$wedd_order;
                
                $result=$img->where($updw)->save($data); // 根据条件更新记录
                $tworesult=$img->where($twow)->save($twodata);
                if ( false !== $result || false !== $tworesult){   
                    $this->success('排序成功!');   
}else{   
$this->error('排序失败!');   
}
            }else{
                $weddpos=$currinfo['pid'];
                $classify['pid']=$weddpos;
                $classify['wedd_order']=array('lt',$wedd_order);
                $twoinfo=$img->where($classify)->order('wedd_order desc')->find();
                
                $updw['id']=$currinfo['id'];
                $data['wedd_order']=$wedd_order-1;
                
                $twow['id']=$twoinfo['id'];
                $twodata['wedd_order']=$wedd_order;
                
                $result=$img->where($updw)->save($data); // 根据条件更新记录
                $tworesult=$img->where($twow)->save($twodata);
                if ( false !== $result || false !== $tworesult){   
                    $this->success('排序成功!');   
}else{   
   $this->error('排序失败!');   
}
            }
        }
//向下排序
        public function weddorderdown(){
            $id=I('get.id');
            $where['id']=$id;
            $wedd_order=I('get.wedd_order');
            //根据id获取整条数据
            $img=M('img');
            $currinfo=$img->where($where)->find();
            
            //print_r($currinfo);
            //判断是否为子分类,若为子分类,则查出pid相同的数据,若不为只分类,则查出wedd_pos相同的数据
            if($currinfo['pid']==0){
                $weddpos=$currinfo['wedd_pos'];
                $classify['wedd_pos']=$weddpos;
                $classify['wedd_order']=array('gt',$wedd_order);
                $twoinfo=$img->where($classify)->order('wedd_order asc')->find();
                if(!$twoinfo){
                    $this->error('已经排在末尾');
                }
                
                $updw['id']=$currinfo['id'];
                $data['wedd_order']=$wedd_order+1;
                
                $twow['id']=$twoinfo['id'];
                $twodata['wedd_order']=$wedd_order;
                
                $result=$img->where($updw)->save($data); // 根据条件更新记录
                $tworesult=$img->where($twow)->save($twodata);
                if ( false !== $result || false !== $tworesult){   
                    $this->success('排序成功!');   
}else{   
                    $this->error('排序失败!');   

            }else{


                $weddpos=$currinfo['pid'];
                $classify['pid']=$weddpos;
                $classify['wedd_order']=array('gt',$wedd_order);
                $twoinfo=$img->where($classify)->order('wedd_order asc')->find();
                if(!$twoinfo){
                    $this->error('已经排在末尾');
                }
                
                $updw['id']=$currinfo['id'];
                $data['wedd_order']=$wedd_order+1;
                
                $twow['id']=$twoinfo['id'];
                $twodata['wedd_order']=$wedd_order;
                
                $result=$img->where($updw)->save($data); // 根据条件更新记录
                $tworesult=$img->where($twow)->save($twodata);
                if ( false !== $result || false !== $tworesult){   
                    $this->success('排序成功!');   
}else{   
$this->error('排序失败!');   
}
            }
        }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值