1.在控制器MainController里面写一个方法,调用Nation表中的数据。
public function zhuyemian()
{
$n = D("Nation");//造一个Nation对象
$attr = $n->select();//查询所有数据,返回的是一个二维数组。
$this->assign("n",$attr);//将二维数组注册到模板里面显示.
$this->show();//调用模板显示
}
2.新建一个显示的模板文件zhuyemian.html
<body>
<table width="100%" border="1" cellpadding="0" cellspacing="0">
<tr>
<td>代号</td>
<td>名称</td>
<td>操作</td>
</tr>
<foreach name="n" item="v"><!--用foreach内置标签标签循环出表格信息,v代表小数组。-->
<tr>
<td>{$v.code}</td><!--注意这里是{$v.code},而不是{$v[0]},因为查到的数据是二维关联数组-->
<td>{$v.name}</td>
<td><a href="__CONTROLLER__/xiugai/code/{$v.code}">修改</a><!--因为是在同一个控制器里面,可以直接用__CONTROLLER__获取到该控制器的路径,后面写上xiugai方法,再在后面写要传的值的名称,最后写上值。路径不能写死,要写成动态的,模板里面的所有路径都尽量不要写死,都要用常量信息写。-->
<a href="__CONTROLLER__/shanchu/code/{$v.code}" onclick="return confirm('确定删除吗?')">删除</a></td><!--指向删除方法并且传一个code值,code值也是{$v.code}-->
</tr>
</foreach>
</table>
</body>
3.显示页面
4.做修改显示页面xiugai.html
<body>
<form action="__ACTION__" method="post"><!--action指向当前控制器,只要是找链接、路径都要用常量信息写,不要写死-->
<input type="hidden" name="Code" value="{$nation.code}" />
<div>名称:<input type="text" name="Name" value="{$nation.name}" /></div>
<div><input type="submit" value="修改" /></div> </form>
</body>
5.在控制器MainController里面写修改方法
public function xiugai($code="")//xiugai方法里面要实现2个逻辑,1是显示页面,2是修改信息。
{
$n = D("Nation");
if(empty($_POST))//判断POST数组是否为空,如果是空的,就显示页面。
{
$nation = $n->find($code);//find只找1条数据,并且是一维数组。
$this->assign("nation",$nation);
$this->show();
}
else//POST数组不为空就执行修改逻辑
{
//修改
$n->create();//自动收集表单,create收集表单比较智能,有别的表单会自动忽略掉,比如注册账号的时候会让用户输入2个密码,这样就需要把2个密码框中的一个设置成列名,另外一个随便设置一个非列名,这个不是列名的密码框会自动忽略掉。所以不需要提交的表单不用列名就可以。
$r = $n->save();//save方法是修改的方法
if($r)
{
$this->success("修改成功","zhuyemian");//修改成功后,提示“修改成功”并且跳转到zhuyemian.html
}
else
{
$this->error("修改失败");//修改失败提示“修改失败。”
}
}
}
6.点击修改,跳转到修改页面,并且传对应的code值。
修改成功后,点击“修改”。
7.在控制器MainController里面写删除方法
public function shanchu($code)//删除方法也需要一个code
{
$n=D("Nation");//造对象
$r = $n->delete($code);//调用删除方法,直接把主键值作为参数放在()里面就可以。
if($r)
{
$url = U("zhuyemian");//用U方法造一个路径
$this->success("删除成功",$url);//把造的路径放在要跳转的页面里面,注意不能直接也页面,会出错。
}
else
{
$this->error("删除失败");
}
}
thinkphp3.2.3使用手册
8.模板
(1)变量输出
变量输出和smarty模板时一样的,都是{$name}。
(2)系统变量的输出
{$Think.server.script_name} // 输出$_SERVER['SCRIPT_NAME']变量
{$Think.session.user_id} // 输出$_SESSION['user_id']变量
{$Think.get.pageNumber} // 输出$_GET['pageNumber']变量
{$Think.cookie.name} // 输出$_COOKIE['name']变量
{$Think.const.MODULE_NAME}//输出常量
{$Think.config.db_charset}//输出配置参数
{$Think.lang.page_error}//取语言
(3)使用函数(用|调用)
{$data.name|md5}//$data.name调用md5
-
表示date函数传入两个参数,每个参数用逗号分割,这里第一个参数是{$create_time|date="y-m-d",###}//
y-m-d
,第二个参数是前面要输出的create_time
变量,因为该变量是第二个参数,因此需要用###标识变量位置,编译后的结果是:<?php echo (date("y-m-d",$create_time)); ?>
(4)默认值输出
{$Think.get.name|default="名称为空"}//默认值输出使用的是default,实际上也是一个函数。
(5)使用运算符
对模板输出使用运算符,也包括“+”“ ” “*” “/”和“%”。
(6)模板继承
模板继承是一项更加灵活的模板布局方式,模板继承不同于模板布局,甚至来说,应该在模板布局的上层。模板继承其实并不难理解,就好比类的继承一样,模板也可以定义一个基础模板(或者是布局),并且其中定义相关的区块(block),然后继承(extend)该基础模板的子模板中就可以对基础模板中定义的区块进行重载。
示例:a.做一个父类的方法
public function fu()
{
$this->show();
}
b.做父类的显示页面
<title>无标题文档</title>
<block name="tou"></block><!--做头部的区域,子类文件可以在这里继承头部-->
</head>
<body>
<div style="width:100%; height:200px; background-color:red"></div>
<block name="neirong"></block><!--做body的区域,子类文件可以在这里继承body-->
<div style="width:100%; height:100px; background-color:green"></div>
</body>
c.做子模板的方法
public function zi()
{
$this->show();
}
d.做子类的显示页面
<extend name="fu" /><!--extend代表继承的意思,name里面是要继承的模板的名字-->
<block name="tou">
<title>测试子模板</title>
</block> <block name="neirong">
<div style="width:100%; height:300px; background-color:black"></div>
</block>
这样显示出来的页面就是子页面,但是头部和尾部都继承了父页面。
(7)包含文件
在当前模版文件中包含其他的模版文件使用include标签,标签用法:
<include file="Public/header" /> // 包含头部模版header
<include file="Public/menu" /> // 包含菜单模版menu
<include file="Blue/Public/menu" /> // 包含blue主题下面的menu模版
(8)比较标签
他们的用法基本是一致的,区别在于判断的条件不同,并且所有的比较标签都可以和else标签一起使用。
例如:<eq name="name" value="value">value</eq>表示name变量的值等于value就输出
(9)import标签
传统方式的导入外部JS和CSS文件的方法是直接在模板文件使用:
<script type='text/javascript' src='/Public/Js/Util/Array.js'>
<link rel="stylesheet" type="text/css" href="/App/Tpl/default/Public/css/style.css" />
系统提供了专门的标签来简化上面的导入:
第一个是import标签 ,导入方式采用类似ThinkPHP的import函数的命名空间方式,例如:
-
<import type='js' file="Js.Util.Array" />
Type属性默认是js, 所以type='js'可以不写。
还可以支持多个文件批量导入,例如:
<import file="Js.Util.Array,Js.Util.Date" />
9.SESSION和Cookie
SESSION在thinkphp里面不需要加session_start()开启了,在配置文件里面有一项配置是true默认开启的。
SESSION存储数据
session(array('name'=>'session_id','expire'=>3600));
Session初始化设置方法无需手动调用,在Think\App类的初始化工作结束后会自动调用,通常项目只需要配置SESSION_OPTIONS
参数即可,SESSION_OPTIONS
参数的设置是一个数组,支持的索引名和前面的session初始化参数相同。
默认情况下,初始化之后系统会自动启动session,如果不希望系统自动启动session的话,可以设置SESSION_AUTO_START
为false,设置方式:
'SESSION_AUTO_START' =>false
Session赋值比较简单,直接使用:
session('name','value'); //设置session
Session取值使用:
$value = session('name');
// 获取所有的session 3.2.2版本新增
$value = session();
删除某个session的值使用:
session('name',null); // 删除name
要判断一个session值是否已经设置,可以使用
// 判断名称为name的session值是否已经设置
session('?name');
Cookie设置
cookie('name','value'); //设置cookie
cookie('name','value',3600); // 指定cookie保存时间
还可以支持参数传入的方式完成复杂的cookie赋值,下面是对cookie的值设置3600秒有效期,并且加上cookie前缀think_
cookie('name','value',array('expire'=>3600,'prefix'=>'think_'))
获取cookie很简单,无论是怎么设置的cookie,只需要使用:
$value = cookie('name');
如果没有设置cookie前缀的话 相当于
value = $_COOKIE['name'];
删除某个cookie的值,使用:
cookie('name',null);
要删除所有的Cookie值,可以使用:
cookie(null); // 清空当前设定前缀的所有cookie值
cookie(null,'think_'); // 清空指定前缀的所有cookie值