美文网首页
CI基本理解

CI基本理解

作者: playman | 来源:发表于2018-06-24 21:47 被阅读0次

    PHP的CI框架的基本理解

    控制层
    视图层
    模型层
    操作数据库
    AR操作

    CI学习

    • 访问url使用的是pathinfo
    • 入口文件.php/控制器/动作
    • 默认控制器是welcome
    • 默认动作是index

    控制器

    • 不需要加后缀。直接是类名.php
    • 文件名全部小写。例如:user.php
    • 所有的控制器,直接或间接继承自CI_Controller类
    • 以下划线开头的方法,不能够被请求。
    • 只有public的方法,才能作为动作

    视图层

    • $this->load->view('user_index');//可以加载多次
    • $this->load->view('user/index');//区分路径
    • 分配变量$this->load->vars('title','标题');
    • 推荐使用短标签

    CI的超级对象

    • 当前的控制器对象

    • 属性

    • $this->load装载器

    • $this->load->view()装载视图

    • $this->load->vars()分配变量到视图

    • $this->load->database()装载数据库操作对象

    • $this->load->model()装载模型对象

    • $this->load->helper()装载帮助

    • $this->uri操作uri对象

    CI_URI的实例
    
    • $this->input
    是CI_Input类的实例
    CI_Input类提供的方法
    $this->input->post('username');//$_POST['username']_
    $this->input->server('DOCUMENT_ROOT'); //$_SERVER['DOCUMENT_ROOT'];_
    在视图层直接用$this来访问超级对象。
    

    操作数据库

    在autoload.php中修改$autoload['libraries'] = array('database');即可自动加载。
    在config中的database.php中,里面前缀参数可以配置,同时将交换前置进行修改。

    'swap_pre' => 'swap_' 这一条写上之后,在sql语句中的前缀可以写成swap_,然后自动转换成下面的
    'dbprefix' => 'blog_'
    

    AR模型(Active Record)

    在最新的CI中不用配置AR,已经自动开启了
    使用获取数据,不用自己写表前缀(前提是已经配置了表前缀)。

    $res = $this->db->get('users');
    //      var_dump($res);
    foreach($res->result() as $item){
        echo $item->id;
        echo " ";
        echo $item->name;
        echo "<br/>";
    }
    

    插入,传入参数是表名和数据

    $data = array(
        'name'=>'usersss'
    );
    $bool = $this->db->insert('users', $data);
    if($bool){
        var_dump($bool);
        echo $this->db->insert_id();
    }
    

    修改,传入条件是表名,数据,条件

    $data = array(
        'name'=>'users666'
    );
    $bool = $this->db->update('users',$data,array('id'=>3));
    var_dump($bool);
    

    删除,传入参数表名和条件

    $data = array('id'=>'2');
    $bool = $this->db->delete('users', $data);
    var_dump($bool);
    

    带条件的查询

    $res = $this->db->select('name')
           ->from('users')
           ->where('id >=',3)
           ->limit(3,2)
           ->order_by('id desc')
           ->get();
    
    var_dump($res);
    foreach($res->result() as $item){
        echo $item->name;
        echo "<br />";
    }
    
    注意:limit的顺序与正常sql语句的顺序相反。同时注意操作符前要有空格
    

    检查最后执行的sql语句

    var_dump($this->db->last_query());
    

    简单的where条件查询

    $res = $this->db->where('name','user3')->get('users');
    $res = $this->db->where('name =','user3')->get('users');
    
    $res = $this->db->where('name like','%user%')->get('users');
    

    where多条件(利用数组写参数)

    $res = $this->db->where(array('name'=>'users', 'id ='=>121))->get('users');
    

    core层的应用扩展

    在里面可以创建自己的内容,然后同过自己写的内容去完成一些重复的操作。

    • 例如
      在core文件夹中,创建一个类,继承自CI_Controller
      在controller文件夹的里面,都继承自己创建的类

    libraries里面可以做扩展

    前缀可以在config中进行修改

    CI中相关url函数

    • load进来,$this->load->helper('url');
    • site_url('user/insert')使用,会自动解析
    • $autoload['helper'] = array('url');自动加载

    相关文章

      网友评论

          本文标题:CI基本理解

          本文链接:https://www.haomeiwen.com/subject/gawsyftx.html