如果父类有_initialize()方法,子类用任何方法前都会调用父类的 _initialize方法,避免这种现象可以在子类中声明_initialize()方法,可以控制是否调用父类的_initialize方法
class ExcelController extends CommonController{ function _initialize() { parent::_initialize(); echo 'ExcelController'.PHP_EOL; } }
前台模板文件{$a} 在某些位置不能被成功替换,例如{afdasd{$a}}解决办法 直接写成<?php echo($a); ?>
某些数组变量无法被解析可以把$vo.size 替换成$vo[‘size’]试试
通过一个Thinkphp完成多个项目
1、单独取压缩包中的Thinkphp文件夹
2、在单独的项目内创建一个引入文件
3、通过浏览器访问该index.php 会创建相应的目录
创建除另外一个项目分组外的另外分组
自动创建后台目录
自动生成控制器
生成Admin模块的目录,并生成一个默认的控制器类AdminControllerIndexController
。 如果需要生成更多的控制器类,可以定义BUILD_CONTROLLER_LIST
常量,例如:
//
绑定
Admin
模块到当前入口文件
- define('BIND_MODULE','Admin');
- define('BUILD_CONTROLLER_LIST','Index,User,Menu');
- define('APP_PATH','./Application/');
- require './ThinkPHP/ThinkPHP.php';
复制代码
访问后会自动生成三个指定的控制器类:
- AdminControllerIndexController
- AdminControllerUserController
- AdminControllerMenuController
品字框架传值
品字形框架通过index.html引入三个left.html/right.html/head.html,在index.html中不能使用”./left.html”, 比喻用单独的方法引入__CONTROLLER__/left,这样控制器才能传值。
显示所有常量
品字形框架点击替换
index.html(head.html/left.html/right.htm),点击left中连接,替换右边
使用自动验证时,
页面没有显示
使用dump($info->getError());可以
空控制器
跨控制器调用
$obj = A(”abc”); $obj->fun();
$obj = A(”admin/abc”); $obj->fun();
R函数是对A方法的封装
$user = new UserController; === $user=A(“User”);
$user = new UserController;
$user->fun(); === R(“User/fun”);
跨模块调用
R(“Home/User/fun”);
R(“Book://Home/User/fun”);
SQL匹配顺序
SELECT%DISTINCT%%FIELD%FROM %TABLE%%JOIN%%WHERE%%GROUP%%HAVING%%ORDER%%LIMIT% %UNION%%COMMENT%
having()方法设置查询条件,where()设置查询条件
having 和 where区别
① 使用有先后顺序
② where price>100 having price>100
③ where 设置条件,字段必须是数据表中存在的字段
④ having 设置条件,字段必须是select语句查询出来的字段可以使用
模版页面通过get传参数http://.../good_id/2;控制中可以直接使用echo $good_id;//2
模板输出时间
TP验证
十二、
十三、
十四、
十五、
十六、
多语言支持
1、
2、
3、
4、
变量会被替换
html,if标签使用
$vo.auth_id eq $vo2.auth_pid报错不能用
condition里面访问变量,不能用点的形式,应该用['']的形式访问
超级管理员
表前缀sw_时
操作效果一样
自增序号,而且默认变量就是$i,也就是说在你的volist标签之内,可以直接使用$i
<volist name="vlist" id="v">
<{$i}> // 直接使用$i
</volist>
去除最右空格
字符串分割数组
数组连接字符串
模板volist自增变量
SQL排序
模版输出多个空格
创建表
DROP TABLE IF EXISTS `sw_user`;
CREATE TABLE `sw_user` (
`user_id` int(11) NOT NULL AUTO_INCREMENT COMMENT '自增id',
`username` varchar(128) NOT NULL DEFAULT '' COMMENT '登录名',
`password` varchar(32) NOT NULL DEFAULT '' COMMENT '登录密码',
`user_email` varchar(64) NOT NULL DEFAULT '' COMMENT '邮箱',
`user_sex` tinyint(4) NOT NULL DEFAULT '1' COMMENT '性别',
`user_qq` varchar(32) NOT NULL DEFAULT '' COMMENT 'qq',
`user_tel` varchar(32) NOT NULL DEFAULT '' COMMENT '手机',
`user_xueli` tinyint(4) NOT NULL DEFAULT '1' COMMENT '学历',
`user_hobby` varchar(32) NOT NULL DEFAULT '' COMMENT '爱好',
`user_introduce` text COMMENT '简介',
`user_time` int(11) DEFAULT NULL,
`last_time` int(11) NOT NULL DEFAULT '0',
PRIMARY KEY (`user_id`)
) ENGINE=InnoDB AUTO_INCREMENT=133 DEFAULT CHARSET=utf8 COMMENT='会员表';
/*!40101 SET character_set_client = @saved_cs_client */;
设置auto_increment 从133开始,插入数据时可以是任意值
验证码点击更换
<img src="__CONTROLLER__/verifyImg" onclick= "this.src='__CONTROLLER__/verifyImg/Math.random()'" />
疑难杂症,验证码有时不显示;
public function verifyImg(){
ob_end_clean(); //增加这句
$Verify = new ThinkVerify();
$Verify->fontSize = 16;
$Verify->length = 1;
$Verify->imageW =100;
$Verify->imageH =25;
$Verify->useNoise = false;
$Verify->entry();
}
I函数获取表单数据
I(‘post.name’);没毛病,获取全部数据I(‘post.’)别忘记这个’.’
当想mysql某插入有某字段设置了unique且和之前相同时,会报错,并停止运行
ThinkPHP 模板中无法计算
<td>{$listSum.goods_amount}</td>
无法进行计算需要使用
<td>{$list[goods_amount]- $listSum[cost_amount]-$listSum[shipping_amount]}</td>
获得某时间戳的下个月初时间戳(自己写)
$i=@strtotime(@date('Y',$i).'-'.@(date('m',$i)+1).'-1 00:00:00'))