牛骨文教育服务平台(让学习变的简单)
博文笔记

TP5 小知识

创建时间:2017-11-09 投稿人: 浏览次数:802

tp5 模型查询自动分页

官方手册上写的是在controller里 db(XX)->paginate(10);

在model里采用分页可以这样写


当前model查询出数据对象$userList 然后分页可以用$userList调用render()这个方法,如果你的$userList 是数组 就会报错:Call to a member function render() on array 。控制器中接收到返回值如下处理:


模板上只需要{$page}即可显示分页。

可在官方手册上搜索:分页

仔细查看文档即可。

2018-4-11


tp5 表单提交的数组获取值的时候报错 ariable type error:array 那么需要加一个修饰符

官方手册:


2018-4-7


官方手册上查询数据都是在控制器直接db("xx")->select();如果在controller里调用model里查询数据的方法,那么返回给控制器的一般是数据对象,如何把tp5在model里查询出的数据对象转化为数组呢,手册上说:5.0.4+ 支持模型中单独设置查询数据集的返回对象的名称:


这样打印的结果$menulist 即为数组类型。

18-3-31


1.tp5获取前端传过来的值

用tp3的时候,表单传的值直接用$_POST获取,今天用到tp5的时候,看到了助手函数里面的input(),支持默认值和过滤。

input($key = "", $default = null, $filter = "") //变量名,默认值,过滤方法

例如

input("post.comments", "挂件", "htmlspecialchars");


2.tp5的model里查询结果返回的是对象,那怎么获取data里面的数据呢?

比如$res是返回的对象, 它的data里面有我们查询的id和username,

如果是用的find()直接 $res["id"]  $res["username"] 即可获得。

如果是select() 那么是二维数组,$res[0]["id"],$res[0]["username"] 即可获得二维数组中的键为0的数组的相关值

有兴趣知道原因可看:

http://blog.csdn.net/qq_15096707/article/details/62227624


3.tp5 点击更换验证码js

onclick="javascript:this.src=this.src+"?time="+Math.random()" 

直接写在验证码的img标签里面,不用写函数了。

tp5验证码常用配置:写在全局config.php里面即可。

    "captcha" =>    [
    		//验证码字符集合
    		"codeSet" =>		"ASDFGHJKLPUYTREWQXCVBNM123456789asdfghjkmnbvcxqwertyp",
    		// 验证码位数
    		"length"      =>  4,
    		//验证后重置
    		"reset" 	=>	true,
    		//图片宽度
    		"imageW"	=>	150,
    		//图片高度
    		"imageH"	=>	30,
    		//使用背景图片  
    		"useImgBg"  =>false,
    		//验证码字体大小(px)
    		"fontSize"  =>	17,
    		//是否画混淆曲线
    		"useCurve"  =>  true,
    		//是否添加杂点  
    		"useNoise"  =>	false,
    		//验证码过期时间(s)
    		"expire"  =>	600,
    ],



4.tp5 数据库操作新增或保存save()

模型的新增和更新方法都是save方法,系统有一套默认的规则来识别当前的数据需要更新还是新增。

  • 实例化模型后调用save方法表示新增;
  • 查询数据后调用save方法表示更新;
  • save方法传入更新条件后表示更新;

如果你的数据操作比较复杂,可以显式的指定当前调用save方法是新增操作还是更新操作。

显式更新数据:

// 实例化模型
$user = new User;
// 显式指定更新数据操作
$user->isUpdate(true)
    ->save(["id" => 1, "name" => "thinkphp"]); //最好不要用这个,直接update(条件)来更新

显式新增数据:

$user = User::get(1);
$user->name = "thinkphp";
// 显式指定当前操作为新增操作
$user->isUpdate(false)->save();

手册上有声明:注意不要在一个模型实例里面做多次更新,会导致部分重复数据不再更新,正确的方式应该是先查询后更新或者使用模型类的update方法更新。 

那么更新的时候 直接 $user->update("条件")即可,可不用save()来更新。

新增的时候 用save() 最好指定 isUpdate(false)。



5.{:url()}里面用变量是不需要引号的,也就是说 直接 {:url($val["url"])} 即可正确解析

18-4-1


6.tp5 ajax请求返回渲染后的模板


这个问题出现的原因是因为我想局部刷新左侧菜单,但是我通过返回的数组用Js追加元素的方式刷新以后会出现布局的偏移,虽然是一点点,但是很难受,最后想到了之前tp3.2.3可以直接返回模板,所以就想在tp5也这么处理,这样局部刷新就很简单,不用遍历数据,清空,追加等等操作。

正常的请求不都是 echo json_encode($arr)嘛,今天想着把渲染后的模板返回给ajax请求,试了半天也没试出来,

去TP官方论坛,特意找到了版主问了这个问题,版主几分钟后上线回答问题,没有回答我,估计是我问的太简单了。

最后在tp群里找到了解决的方法。

多次尝试代码如下:

	$this->assign("res_t",$res_t);  //模板赋值
	$html=$this->fetch("common/left"); //渲染模板,但是不直接return
	return  $html; //输出返回值  在这里输出的就是left.html的页面内容,输出的是字符串类型的

上面这个是自己结合群里提到的试验出来的,但是实际上还是要看手册,大腿告诉我,我这么写不规范,规范的写法应该是返回数组,通过js追加元素实现局部刷新,但是写法还是可以标准一些:


$this->assign("res_t",$res_t);
Config::set("default_ajax_return","html"); //配置ajax默认的返回格式
return $this->fetch("common/left"); //这样就不会输出模版,完成渲染并当作返回值,如果没有上面的配置,return $this->fetch()会报错

至于ajax接收到返回值,只需要用jquery转换成对象就可以了:

console.log($(data).html())   //这个输出的就是html内容。$(data) 就把返回值data由字符串格式转换成了对象

对于这个问题像个半天,总结了一下还是自己看手册没看全,如果知道更改了默认格式就可以 return $this->fetch();那么就不会折腾一下午了。当然,最后也发现遍历数组追加元素偏移的原因是一个class 属性少了一个字母...少了一个字母...一个字母....

当然了,这也是经验,毕竟自己踩过的坑,印象才最深刻偷笑偷笑,还是要感谢新加的群里的大神们的热心帮助,让我找到了解决问题的门路,独学而无友,则孤陋而寡闻。

当工作环境已经没人能给你思路,自己也看不见能让技术提高的机会的时候,趁着年轻,多走走。



7.tp5 url带参数,url传参数get不到


格式

 {:url("admin/index/index",["id"=>1,"name"=>"admin"])}

控制器里获得参数不能用$_GET

$request = Request::instance();
$res=$request->param();
halt($res);//包含id和name

8.tp5关联模型,关联模型后查询结果对象取值,关联模型在model里进行查询


后记:关联模型好像不能关联删除和更新(可能是我操作的不对,也可能是本身就不可以了),关联模型查询出来的数据对象取值又比较麻烦,鉴于不能关联删除,已经没有优势,还是用链式操作进行关联查询吧 (2017-11-29)

今天看了一下关联模型,在手册上的例子都是在控制器中直接查询数据,如果在model里查询数据该怎么关联查询呢?

首先,需要设置关联模型:

 	//关联模型
 	 public function connectmenushow(){  //一对一关联 还有一对多和从属关联,这里不列举了,去手册上看
        return $this->hasOne("AdminMenuShow", "uid", "id")->field("uid,menu_id");  
    } 

hasOne("a","b","c")//关联的模型a,外键b,当前模型的主键c


上面设置的关联模型为 adminmenushow这张表,外键是uid  当前表的主键是id 关联查询字段是uid 和menu_id(设置关联手册上有例子)

如果关联模型不懂的话 可以看这篇文章:http://blog.csdn.net/github_37512301/article/details/75675054

我想说的是查询数据和取出值:

手册上的例子是在控制器里用db 连接数据库查询,在model里这样查询:

	public function show_admin(){
		$res=self::with("connectmenushow")->select();//connectmenushow 是上面设置关联的函数名
		foreach ($res as $k => $v) {
			//关联模型数据对象
			$obj = $v->relation;
			$arr[$k]["menu_id"] = $obj["connectmenushow"]["menu_id"];   //这是关联模型的数据
			$arr[$k]["username"] = $v["username"];//主表数据
			$arr[$k]["password"] = $v["password"];//主表数据
		
		}
		halt($arr);
		
	}

主要用到了 with() ,打印结果是对象,但是对象里面有个relation属性,如图:


这里面包含上面关联模型设置的表里面的字段数据,获取这些数据要先从$v这个对象中选中这个属性,然后选中数组,然后先择相应的下标,这样即可获得关联查询的所有内容。



有帮助的话,点个赞,谢谢

声明:该文观点仅代表作者本人,牛骨文系教育信息发布平台,牛骨文仅提供信息存储空间服务。