thinkphp入门?thinkphp框架入门
今天给各位分享thinkphp入门的知识,其中也会对thinkphp框架入门进行解释,如果能碰巧解决你现在面临的问题,别忘了关注本站,现在开始吧!
thinkphp3.1快速入门路由 怎么输出
变量输出
例如,在控制器中我们给模板变量赋值:
$name='ThinkPHP';
$this->assign('name',$name);
$this->display();
然后就可以在模板中使用:
Hello,{$name}!
模板编译后的结果就是:
Hello,<?php echo($name);?>!
这样,运行的时候就会在模板中显示:
Hello,ThinkPHP!
[-more-]
注意模板标签的{和$之间不能有任何的空格,否则标签无效。所以,下面的标签
Hello,{$name}!
将不会正常输出name变量,而是直接保持不变输出:
Hello,{$name}!
普通标签默认开始标记是{,结束标记是}。也可以通过设置TMPL_L_DELIM和TMPL_R_DELIM进行更改。例如,我们在项目配置文件中定义:
'TMPL_L_DELIM'=>'<{',
'TMPL_R_DELIM'=>'}>',
那么,上面的变量输出标签就应该改成:
Hello,<{$name}>!
后面的内容我们都以默认的标签定义来说明。
模板标签的变量输出根据变量类型有所区别,刚才我们输出的是字符串变量,如果是数组变量,
$data['name']='ThinkPHP';
$data['email']='thinkphp@qq.com';
$this->assign('data',$data);
那么,在模板中我们可以用下面的方式输出:
Name:{$data.name}
Email:{$data.email}
或者用下面的方式也是有效:
Name:{$data['name']}
Email:{$data['email']}
当我们要输出多维数组的时候,往往要采用后面一种方式。
如果data变量是一个对象(并且包含有name和email两个属性),那么可以用下面的方式输出:
Name:{$data:name}
Email:{$data:email}
或者
Name:{$data->name}
Email:{$data->email}
系统变量
普通的模板变量需要首先赋值后才能在模板中输出,但是系统变量则不需要,可以直接在模板中输出,系统变量的输出通常以{$Think打头,例如:
{$Think.server.script_name}//输出$_SERVER['SCRIPT_NAME']变量
{$Think.session.user_id}//输出$_SESSION['user_id']变量
{$Think.get.pageNumber}//输出$_GET['pageNumber']变量
{$Think.cookie.name}//输出$_COOKIE['name']变量
支持输出$_SERVER、$_ENV、$_POST、$_GET、$_REQUEST、$_SESSION和$_COOKIE变量。
还可以输出常量
{$Think.const.MODULE_NAME}
或者直接使用
{$Think.MODULE_NAME}
输出配置参数使用:
{$Think.config.db_charset}
{$Think.config.url_model}
输出语言变量可以使用:
{$Think.lang.page_error}
{$Think.lang.var_error}
使用函数
我们往往需要对模板输出变量使用函数,可以使用:
{$data.name|md5}
编译后的结果是:
<?php echo(md5($data['name']));?>
如果函数有多个参数需要调用,则使用:
{$create_time|date="y-m-d",###}
表示date函数传入两个参数,每个参数用逗号分割,这里第一个参数是y-m-d,第二个参数是前面要输出的create_time变量,因为该变量是第二个参数,因此需要用###标识变量位置,编译后的结果是:
<?php echo(date("y-m-d",$create_time));?>
如果前面输出的变量在后面定义的函数的第一个参数,则可以直接使用:
{$data.name|substr=0,3}
表示输出
<?php echo(substr($data['name'],0,3));?>
虽然也可以使用:
{$data.name|substr=###,0,3}
复制代码
但完全没用这个必要。
还可以支持多个函数过滤,多个函数之间用“|”分割即可,例如:
{$name|md5|strtoupper|substr=0,3}
编译后的结果是:
<?php echo(substr(strtoupper(md5($name)),0,3));?>
函数会按照从左到右的顺序依次调用。
如果你觉得这样写起来比较麻烦,也可以直接这样写:
{:substr(strtoupper(md5($name)),0,3)}
默认值
我们可以给变量输出提供默认值,例如:
{$user.nickname|default="这家伙很懒,什么也没留下"}
复制代码
对系统变量依然可以支持默认值输出,例如:
{$Think.get.name|default="名称为空"}
复制代码
默认值和函数可以同时使用,例如:
{$Think.get.name|getName|default="名称为空"}
使用运算符
我们可以对模板输出使用运算符,包括对“+”“–”“*”“/”和“%”的支持。
例如:
运算符使用示例
+{$a+$b}
-{$a-$b}
*{$a*$b}
/{$a/$b}
%{$a%$b}
++{$a++}或{++$a}
--{$a--}或{--$a}
综合运算{$a+$b*10+$c}
在使用运算符的时候,不再支持点语法和常规的函数用法,例如:
{$user.score+10}//错误的
{$user['score']+10}//正确的
{$user['score']*$user['level']}//正确的
{$user['score']|myFun*10}//错误的
{$user['score']+myFun($user['level'])}//正确的
thinkphp主要有什么用
1、他是一个国人开发的php框架,本质上就是相当于将代码逻辑解耦出来,分模块管理,增强类与方法的重用的同时更好的规范代码编写结构,方便二次开发。另外一个就是封装好很多功能,如数据库连接,缓存处理等,可以直接使用以达到快速开发的目的。
2、正如上个问题所说,他是一个国人开发的php框架,意思就是原生文档就是中文的,在我国php使用中占了相对较大的比重,所以一些常见问题可以很容易找到答案。你可以拿他来熟悉框架原理,以及开发一些日常的后台程序,快且简单。但是所有框架的好处都是以损耗性能为前提的,号称速度最快的yaf框架都会比原生php增加10%损耗(官方数据)
综上所述,php框架有很多,主要是方便大家快速开发与减少二次开发工作量的,但本质还是php语言。很多人学习了TP之后就不会用php来做一些基本操作了(上面提到他有很多方法类已经封装好直接用就可以了)。所以最好是学习好php,理解框架的原理,这样无论公司要求你用哪个框架你都能快速上手,否则职业生涯发展会受到限制
thinkphp中怎么写入口文件
入口
(注:这个答案就是原创,入门文件就是这样写,大部分人也是这样写,我也是这样写,只要define('THINK_PATH','./ThinkPHP/');引入THINKPHP文件就可以编写项目了)
文件一般是根目录下的INDEX.PHP
<?php
//应用入口文件
//检测PHP环境
if(version_compare(PHP_VERSION,'5.3.0','<'))die('requirePHP>5.3.0!');
//开启调试模式建议开发阶段开启部署阶段注释或者设为false
define('APP_DEBUG',true);
//定义应用目录
define('APP_PATH','./Application/');
//引入ThinkPHP入口文件
require'./ThinkPHP/ThinkPHP.php';
文章到此结束,如果本次分享的thinkphp入门和thinkphp框架入门的问题解决了您的问题,那么我们由衷的感到高兴!