第一天ci框架开发商城2
ci框架开发商城2
1/28/2016 9:45:52 PM
mvc完整案例 mvc完成新闻的增删改查
news控制器news.php
class News extends CI_controller{
public __construct(){
parent::__construct();
//载入news_model
$this->load->model('news_model');}
public function add(){
$this->load_view('add.html');
}
}
设计一张表news.sql
create database ci;
use ci
create table news(
id int unsigned not null primary key auto_increment,
title varchar(50) not null default '',
author varchar(30) not null default '',
content text,
add_time int unsigned not null default 0)engine=myisam charset=utf8;
连接数据库
数据库相关配置 config/database.php
连接数据库 数据库操作类两种方式只需要加载该类即可,手动载入 或者自动载入
$this->load->database
//需要的地方手动载入
自动载入config/autoload.php
$autoload['libraries'] =array('database');加入database
操作数据库,
定义news模型 继承模型基类CI_Model Model_name 类名首字母大写其他字母小写 文件名 类名的小写版News_model news_model.php
class News_model extends CI_Model{
//构造函数
public function __construct(){
//调用父类构造函数 必不可少
parent::__construct();
//手动载入数据库操作类
$this->load->database(); }
}
操作数据库 $this->db->query($sql);//select返回结果集 insert update delete返回布尔值更希望有一个能够自动完成增删改查的一个功能CI中提供了一个active record类 $this->db->insert/update/delete/get 自动能够拼凑sql语句 支持多种数据库
news_model.php 写完后控制器中调用模型
const TBL='news';
public function add_news($data){
return $this->db- >insert(self::TBL,$data);//ar类完成操作
}
/**
*@param $data array
*@return bool 成功返回* true 失败返回FALSE
*/
控制器 news.php 在构造函数中载入news_model,并写入insert方法
class News extends CI_controller
{
public __construct()
{
parent::__construct();
//载入news_model
$this->load->model('news_model');
}
public function add(){
$this->load_view('add.html');
}
public function insert()
{
//调用news_model
if($this->news_model->add_news()
{echo "插入成功";
}else
{echo "插入失败";}
}
}
视图文件中表单action怎么写?
涉及到ci的辅助函数url
配置config.php中 $config['base_url']="http://localhost/citest"
默认情况下 url函数没有加载
可在配置文件中自动加载 config/autoload.php $autoload['helper']=array('url');
提供了 site_url= base_url+index.php
action="<?php echo site_url('news/insert')?>"
//========控制器news.php
class News extends CI_controller
{
public __construct()
{
parent::__construct();
//载入news_model
$this->load->model('news_model');
}
public function add(){
$this->load_view('add.html');
}
public function insert()
{//获取表单数据
$data['title'] = $_POST['title'];
$data['author'] = $_POST['author'];
$data['content'] = $_POST['content'];
$data['add_time'] = time();
//调用news_model
if($this->news_model->add_news($data)
{echo "插入成功";
}else
{echo "插入失败";}
}
}
new.php中显示新闻列表 news_model加入list _news方法
//======news_model
class News_model extends CI_Model{
//构造函数
public function __construct()
{
//调用父类构造函数 必不可少
parent::__construct();
//手动载入数据库操作类
$this->load->database();
}
/**
*@param $data array
*@return bool 成功返回* true 失败返回FALSE
*/
const TBL='news';
public function add_news($data)
{
return $this->db->insert(self::TBL,$data);//AR类完成操作
}
/**
*@acess public
*@return array
*/
public function list_news()
{
$query = $this->db->get(self::TBl,);
return $query->result_array();
}
} //========控制器news.php
class News extends CI_controller
{
public __construct()
{
parent::__construct();
//载入news_model
$this->load->model('news_model');
}
public function add(){
$this->load_view('add.html');
}
public function insert()
{//获取表单数据
$data['title'] = $_POST['title'];
$data['author'] = $_POST['author'];
$data['content'] = $_POST['content'];
$data['add_time'] = time();
//调用news_model
if($this->news_model->add_news($data)
{echo "插入成功";
}else
{echo "插入失败";}
}
public function index()
{//调用list_news方法
$data['news'] =$this->news_model->list_news();
//在视图文件中展示
$this->load->view('list.html',$data);
} }
list.html视图文件
php控制结构替代语法
<?php foreach($news as $row) : ?>
<tr>
<td><?php echo $row['id'] ?></td>
<td><?php echo $row['title'] ?></td>
<td><?php echo $row['author'] ?></td>
<td><?php echo $row['add_time'] ?></td>
<td><a href="<?php echo site_url('news/edit') ;?>" >编辑</a>
<a href="<?php echo site_url('news/delete');?>" >删除</a></td>
</tr>
<?php endforeach; ?>
//读取数据库操作已完成
第一天ci框架开发商城2的更多相关文章
- 第一天ci框架开发商城1
ci框架开发商城1 1/28/2016 9:43:52 PM userguide删除 system application controllers 控制器 models 模型 views 视图 模板 ...
- 记录使用CI框架开发项目时遇到的问题
关于CI框架在视图文件中怎样引入静态资源文件(js,css,images)的问题: 第一步:在application/config/config.php文件中配置 $config['base_url ...
- CI框架 -- 开发环境、生产环境
开发者常常希望当系统运行在开发环境或生产环境中时能有不同的行为, 例如,在开发环境如果程序能输出详细的错误信息将非常有用,但是在 生产环境这将造成一些安全问题. ENVIRONMENT 常量 Code ...
- CI框架入门笔记
当前(2019-03-22)CodeIgniter 框架的最新版本是 3.1.5,于2017年6月发布,距今快两年了也没有更新,这与 Laravel 的更新速度相比差距太大了.因为确实,它是一个很古老 ...
- ***PHP基于H5的微信支付开发详解(CI框架)
这次总结一下用户在微信内打开网页时,可以调用微信支付完成下单功能的模块开发,也就是在微信内的H5页面通过jsApi接口实现支付功能.当然了,微信官网上的微信支付开发文档也讲解的很详细,并且有实现代码可 ...
- bootstrap框架开发电子商城案例
bootstrap框架开发电子商城案例 玛图 bootstrap 商城框架
- [原创].NET 业务框架开发实战之十 第一阶段总结,深入浅出,水到渠成(后篇)
原文:[原创].NET 业务框架开发实战之十 第一阶段总结,深入浅出,水到渠成(后篇) .NET 业务框架开发实战之十 第一阶段总结,深入浅出,水到渠成(后篇) 前言:接着上篇来. 系列文章链接: [ ...
- struts2框架开发的第一个应用
写这篇博文,主要是帮助那些刚接触struts2框架开发而不知所措的人,希望批评指正 一.先建立一个web project,命名为struts2 二.在webroot/WEB-INF/lib目录下添加如 ...
- CI框架微信开发-自定义菜单
在CI框架下面实现了自定义菜单功能.写了一个model,一个类库.顺便附带access_token的实现方式 <?php class Makemenu{ public $menustr; pub ...
随机推荐
- Mac Pro 日历增强工具 Itsycal
Mac 自带的日历工具一点也不好用,好在 Itsycal 弥补了这个缺陷,效果图如下: 下载地址:https://www.mowglii.com/itsycal/,下载解压后,把 Itsycal.ap ...
- 查找Linux中内存和CPU使用率最高的进程
下面的命令会查看到按照RAM和CPU降序方式的前最高几名进程的列表: [root@iZ25pvjcsyhZ ~]# ps -eo pid,ppid,cmd,%mem,%cpu --sort=-%mem ...
- web报表工具Stimulsoft Reports.Web在mvc项目中使用
Stimulsoft Reports.Web,是一款可以直接在Web中编辑报表的报表工具 web项目技术框架mvc4+easyui+knockoutjs 1.在项目中添加引用 Stimulsoft.B ...
- 如何灵活运用Linux 进程资源监控和进程限制
导读 每个 Linux 系统管理员都应该知道如何验证硬件.资源和主要进程的完整性和可用性.另外,基于每个用户设置资源限制也是其中一项必备技能. 在这篇文章中,我们会介绍一些能够确保系统硬件和软件正常工 ...
- (原创)RecyclerView结合xUtils2.6实现滚动时不加载item,xUtils2.6的源码分析与改造
我们知道xUtils中的bitmapUtils与listview相配合可以实现滚动时暂停加载 只需要一句话: listview.addOnScrollListener(new PauseOnScrol ...
- Eclipse使用Maven tomcat:run命令启动web项目时修改默认端口
- Merge K Sorted Arrays
This problem can be solved by using a heap. The time is O(nlog(n)). Given m arrays, the minimum elem ...
- 448. Find All Numbers Disappeared in an Array
https://leetcode.com/problems/find-all-numbers-disappeared-in-an-array/ 给出一列数,1 ≤ a[i] ≤ n,n是数组大小,有些 ...
- The certificate used to sign ***has either expired or has been revoked. An updated certificate is required to sign and install the application
真机测试的时候弹出这样的提示:The certificate used to sign ***has either expired or has been revoked. An updated ce ...
- mysql基准测试
1. 及注册时有两种主要的策略:①正对整个系统的整体测试(集成式full-stack) ②单独测试mysql(但组件式基准测试single-component) 2.获取系统性能和状态(需要记录的数据 ...