PHP后台传值

前台数据往后台传值,往往是新手最头痛的,最近在学习thinkPHP的时候,也遇到了这种问题,总结一下,往不足之处请大家指教。

一、前台界面代码,往后台传值有两种方式,一种是get,另一种是post,新手入门,不管什么方式吧,往后台传值成功就可以了。

      首先,写一个from表单,

      <form action="{:U(Recom/goodsprice)}" method="post">

      <a href="{:U('Recom/goodsprice',array('price'=>'700'))}">价格大于700</a>//在本案例中就已超链接的方式传值做介绍吧

      </form>

      这个价格就往后台传过去了,传过去后,也要接受要传的值,看步骤二,

二、后台的控制层的代码如下:  

       public function goodsprice(){
           $price = I('price');//这就可以获取前台传的price这个值了
    print_r("price: ".$price." ");//检验一下传值是否成功,需要运行后开前台的源代码是否有这个值
    $model = D('Goods');//选择数据库中的表了,打个比方吧,就叫goods表吧
    $res = $model->selectPrice($price);//关键时刻来了,调用model层的selectPrice函数,顺道把$price这个参数带过去

    $this->assign('res',$res["date"]);//获取数据,命名为res
    $this->assign('page',$res["page"]);//thinkPHP中自带的一种分页方式,很简单,但是需要在model层中进行配置,讲解在下面。

    $this->display();//这个是显示界面的
    }

三、model层的代码如下:

  public function selectPrice($price){
    $this->db(1,"DB_CONFIG1")->db(1);//选择数据库

    $map ['price'] = array('gt',$price); //定义查询条件

    $count = $this->db(1,"DB_CONFIG1")->where($map)->count();//统计条数
    $page = new \Think\Page($count,10);//分页处理
    $show = $page->show();
    $limit = $page->show();
    $limit = $page->firstRow.",".$page->listRows;

    $goodsprice = $this->db(1,"DB_CONFIG1")->limit($limit)->where($map)->select();//sql语句
    print_r($this->getLastSql());//调试专用,输出最后一条sql语句
    $res["date"] = $goodsprice;
    $res["page"] = $show;

    return $res;
  }

具体的代码和步骤就是这么简单,对你有没有帮助啊?

posted @ 2015-05-21 17:15  木子小僧  阅读(959)  评论(0编辑  收藏  举报