一、控制器
1.文件名全小写且不用像tp一样加后缀(例:user.php)
2.所有控制器直接或间接继承CI_Controller类
3.类内方法基本上都是加public修饰
4.方法名以下划线 _
开头的方法,只能在内部调用不能直接访问
二、视图
1.所有视图放在views文件夹内,最好在文件夹里多建几个文件夹,按模块区分
使用$this->load->view(‘folder/file’);
加载视图
视图中不使用模板引擎,直接使用原生PHP输出变量
//分配数组或变量
$this->load->vars(数组/变量);
//循环变量
<?php foreach($var as $k=>$v):?>
<?=$v[‘id’]?>
<?=$v[‘name’]?>
<?php endforeach;?>
//条件判断
<?php if(condition):?>
Code
<?php endif;?>
2.接收GET方法传递的参数$this->uri->segment(位置)
(例:www.douyu.com/index.php/live/index/id/1)
获取这个id值就是$this->uri->segment(4);//位置是从入口文件后开始数
当然,也可以不写id,(例:www.douyu.com/index.php/live/index/1)
代码为$this->uri->segment(3);
3.接收POST方法传递的参数$this->input->post(‘input标签中的name值’);
<input name=’example’>示例</input>
获取以上标签的value值就是$this->input->post(‘example’);
4.返回ajax请求
$data={OBJECT};
$this->output->set_header('Content-Type: application/json; charset=utf-8');
echo json_encode($data);
以上两行代码相当于tp中的$this->ajaxReturn($data);
三、模型
1.准备工作
在application/config/autoload.php
代码中找到$autoload['libraries']
将值改为array('database');
数据库配置文件在application/config/database.php
中作相应的配置
2.CRUD操作
$res=$this->db->get(‘user’);//实例化user表,返回一个对象
$res->result_array();//以数组形式返回user表中的所有数据
$res->row_array();//以数组形式返回user表中的一条数据
$this->db->insert(‘user’,array());//向user表中插入一条数组中的数据
$this->db->insert_id();//返回最近一条插入记录的id
$this->db->affected_rows();//返回数据库操作受影响行数(适用以下的更新和删除操作)
$this->db->update(‘user’,array(),array(‘id’=>3));//将user表中id为3的记录更新为数组中对应的值
$this->db->delete(‘user’,array(‘id’=>1));//删除user表中id为1的记录
3.连贯操作
如果一条SQL语句为’select name from user where id>=10 limit 2,3 order by id asc’;
那么CI的连贯操作就应该为
$this->db->select(‘name’)
->from(‘user’)
->where(‘id /*中间必须有一个空格,没有就会报错)*/ >=’,10)
->limit(3,2) //从哪里开始取,取多少条位置和SQL语句的位置是相反的
->order_by(‘id asc’)
->get()
->result_array();
4.连贯操作中where()的补充
where(‘name’,’sam’) //相当于where `name`=’sam’
where(‘id (空格) !=’,1) //相当于where `id`!=1
where(array(‘name’=>’sam’,’id /*一个空格*/ <’=>2)) //相当于where `name`=’sam’ and id<2
5.如果业务太复杂使用连贯操作不能满足,希望使用原生SQL语句则可以使用以下代码
$this->db->query(SQL语句);
6.查询最近的一条SQL语句使用以下代码
$this->db->last_query();
7.最好所有的数据库操作写在模型中,以便项目维护
8.模型文件名需要全部小写,例:user_model.php
9.对应的模型类则应该是 class User_model (注意大小写)
10.模型类需要直接继承CI_Model类 (注意大小写)
11.在控制器中加载模型
$this->load->model(‘User_model’,’user’);//加载User_model模型,并取别名为user
$this->user->add();//调用user模型中的add方法
剩下一点点的补充:
1.Form表单提交里action的地址应该怎么处理
在application/config/autoload.php
代码中找到$autoload['helper']
将值改为array('url');
action=’<?php echo site_url(‘控制器/方法名’);?>’
2.访问与入口文件同级folder文件夹中的file文件
路径应该是’<?php echo base_url();?>folder/file’
使用wafer2中CI3框架的一些注意事项:
wx.request中data的值需要是对象,使用的是GET方法传递
不管是控制器还是模型,文件名和类名必须完全一致,且首字母必须大写