thinkphp框架,是一堆代码(常量,方法,和类)的集合,框架是一个半成品的应用,还包含一些优秀的设计模式。

框架的使用,代码风格不一样,维护难,项目生命周期短,功能扩展存在局限,好处为,简单,快捷,高效,不需要关注底层结构,专注于业务逻辑

zend framework,官方框架,yii框架,美国华人,laravel轻量级的框架,国外框架,thinkphp国人开发。

什么是mvc,是一种设计模式,将用户的输入,逻辑,输出相分离。输入-控制器,逻辑-模型,视图-输出。

入口文件,对应的控制器,控制器到视图展示模板,和控制器到模型,模型是和数据库的,返回数据,控制器调用模型处理业务逻辑的。

混合编程阶段,模板引擎阶段,mvc阶段。

官网下载:

http://www.thinkphp.cn/

alpha版本为内测版本,beta版本为公测版本,rc版本为候选版本,r版本为release版本,发行版本。

application应用目录

public 存放图片,css等公共静态文件目录

thinkphp框架核心目录

.htaccess分布式配置文件

composer.json给compose软件使用的说明文件

index.php项目入口文件

thinkphp目录下

behavior行为文件目录

org为功能扩展目录

think最核心的目录

vendor第三扩展目录

模板内容获取方法:

$this -> display(); 展示模板
$this -> fetch(); 获取模板(有返回值)
public function login(){
//展示模板
// $this -> display();
$str = $this -> fetch();
// dump打印
dump($str);
}
dump 打印变量,打印方法

thinkphp中的注解是属于服务端的注解,不会在浏览器中输出,而html的会。

public function test(){
$array = array('da','dashu','dashucoding');
//变量分配
$this -> assign('array',$array);
// 函数模板
$this -> display();
}

入口文件:

header('Content-Type:text/html;charset=utf8');
public function test(){
// 实例化student对象
$stu = new Student(); $stu -> id=1;
$stu -> name=dashu;
// 变量分配
$this -> assign('stu', $stu);
// 展示模板
$this -> display();
}

获取服务器的相关信息

获取get请求的信息

获取post请求的信息

获取get和post中信息

获取cookie中的信息

获取session中的信息

获取ThinkPHP中所有配置文件的一个总和

获取get请求中的id {$Think.get.id}
public function test() {
// 展示模板
$this -> display();
}
$Think.server.path
$Think.get.id
$Think.request.pid
$Think.cookie.PHPSESSID
$Think.config.DEFAULT_MODULE

语法格式:

{$变量 | 函数名1 | 函数名2 = 参数1,参数2,...}

函数名1:表示需要使用的第一个函数

函数名2:表示需要使用的第二个函数

参数1、参数2:函数2的参数

// 模板中函数使用
public function test() {
// 定义时间戳
$time = time();
//传递给模板
$this -> assign('time', $time);
// 展示模板
$this -> display();
}

时间戳的格式化,格式化时间戳使用的函数是date

date(‘Y-m-d H:i:s’,时间戳);
<body>
{$time | date='Y-m-d H:i:s',###}
</body>

截取字符串使用函数substr

转化大写使用函数strtoupper

默认值 {$变量名|default=默认值}

// 默认值
public function test() {
// 定义一个空的字符串
$sign = '';
// 传递给模板
$this -> assign('sign', $sign);
// 展示模板
$this -> display();
} 默认值的使用:
{$sign | default='dashucoding'}

运算符:

++	{$a++} 或 {++$a}	自增运算
-- {$a--} 或 {--$a} 自减运算 public function test(){
// 定义两个变量
$a = 10;
$b = 10;
// 传递给模板
$this -> assign('a',$a);
$this -> assign('b',$b);
// 展示模板
$this -> display();
} 在模版中进行运算:
<body>
变量a = {$a},变量b = {$b}<br/>
a+b={$a+$b}<br/>
...
</body>

文件包含

<include file=’需要引入的模版文件’ />

创建出三个模版文件
body.html
foot.html
head.html // 展示头部
public function head() {
// 展示模板
$this -> diaplay();
}
// 展示body
public function body() {
// 展示模板
$this -> dispaly();
}
// 展示尾部
public function foot() {
// 展示模板
$this -> display();
} body.html <body>
<include file="head.html"/>
<div>dashucoding</div>
<include file="foot.html"/>
</body> <body>
<include file="Test/head"/>
<div>dashucoding</div>
<include file="Test/foot"/>
</body> <include file=’需要引入的模版文件’ 参数名=’参数值’ /> <body>
<include file="Test/head"/>
<div>dashucoding</div>
<include file="Test/head" title="dashu"/>
</body> foot.html
<div>da [title] </div>

循环遍历volist标签、foreach标签

volist语法:
<volist name="需要遍历的模板变量名" id="当前遍历到的元素">
循环体
</volist> foreach($variable as $value){
循环体
} foreach语法格式:
foreach($variable as $value){
} <foreach name="需要遍历的模板变量名" item="当前遍历到的元素">
循环体
</foreach>

一维数组遍历

// 数组遍历
public function test(){
// 定义一维数组
$array = array('da', ' dashu', 'dashucoding);
// 二维
$array2 = array(
array('da','dashu','dashucoding'),
array('da','dashu')
);
// 传递给模板
$this -> assign('array', $array);
// 展示模板
$this -> display();
}
<body>
<volist name="array" id="vol">
</volist>
{$vol}
<hr/> <foreach name="array" item="for">
{$for}
</foreach>
</body>

<if condition=’条件表达式’>
...
<elseif condition=’条件表达式2’/>
...
<elseif condition=’条件表达式3’/>

<else/>
...
</if>
public function test(){
//输出今天的星期数字
$day = date('N',time());
// 传递给模板
$this -> assign('day',$day);
$this -> display();
} <if condition="$day == 1">
星期一
<elseif condition="$day == 2"/>
星期二
...
<else/>
星期天

禁用php标签:

TMPL_DENY_PHP: false

未完!!!

结言

好了,欢迎在留言区留言,与大家分享你的经验和心得。

感谢你学习今天的内容,如果你觉得这篇文章对你有帮助的话,也欢迎把它分享给更多的朋友,感谢。

作者简介

达叔,理工男,简书作者&全栈工程师,感性理性兼备的写作者,个人独立开发者,我相信你也可以!阅读他的文章,会上瘾!,帮你成为更好的自己。长按下方二维码可关注,欢迎分享,置顶尤佳。

感谢!承蒙关照!您真诚的赞赏是我前进的最大动力!

这是一个有质量,有态度的公众号

喜欢本文的朋友们

欢迎长按下图关注订阅号

收看更多精彩内容

PHP全栈从入门到精通1的更多相关文章

  1. spring boot + vue + element-ui全栈开发入门——开篇

    最近经常看到很多java程序员朋友还在使用Spring 3.x,Spring MVC(struts),JSP.jQuery等这样传统技术.其实,我并不认为这些传统技术不好,而我想表达的是,技术的新旧程 ...

  2. spring boot + vue + element-ui全栈开发入门——基于Electron桌面应用开发

     前言 Electron是由Github开发,用HTML,CSS和JavaScript来构建跨平台桌面应用程序的一个开源库. Electron通过将Chromium和Node.js合并到同一个运行时环 ...

  3. spring boot + vue + element-ui全栈开发入门——spring boot后端开发

    前言 本文讲解作为后端的spring boot项目开发流程,如果您还不会配置spring boot环境,就请点击<玩转spring boot——快速开始>,如果您对spring boot还 ...

  4. spring boot + vue + element-ui全栈开发入门

    今天想弄弄element-ui  然后就在网上找了个例子 感觉还是可以用的  第一步是完成了  果断 拿过来  放到我这里这  下面直接是连接  点进去 就可以用啊 本想着不用vue   直接导入连接 ...

  5. spring boot + vue + element-ui全栈开发入门——windows开发环境

     一.node.js开发环境 windows系统,去网站https://nodejs.org/en/download/,下载对应的安装程序,并安装Windows Installer (.msi) 接下 ...

  6. spring boot + vue + element-ui全栈开发入门——前端列表页面开发

     一.页面 1.布局 假设,我们要开发一个会员列表的页面. 首先,添加vue页面文件“src\pages\Member.vue” 参照文档http://element.eleme.io/#/zh-CN ...

  7. spring boot + vue + element-ui全栈开发入门——项目部署

     前言 常用的部署方式有两种: 1.是把生成好的静态页面放到spring boot的static目录下,与打包后的spring boot项目一起发布,当spring boot运行起来后,自然而然就能访 ...

  8. spring boot + vue + element-ui全栈开发入门——前端编辑数据对话框

     需求 1.点击“添加”按钮,弹出录入数据的对话框窗口,并录入数据,如果数据有误则不允许提交.数据填写完毕后,点击“保存”按钮,调用http协议提交数据,提交完毕刷新页面数据.点击“取消”按钮关闭对话 ...

  9. spring boot + vue + element-ui全栈开发入门——集成element-ui

     一.IDE开发工具 常用的开发工具有webstorm和sublime. 我个人喜好用Atom+插件的形式 打开Atom,在file --> settings --> packages中收 ...

随机推荐

  1. 使用token做认证

    对当前用户,使用base64加密token,再解密token,但是不如JWT加密安全 import time import base64 import hmac def generate_token( ...

  2. 使用Postman测试https接口时的小问题记录

    测试本地的WebApi接口时,接口是https,自己写的用httpclient测试是可以的, 用postman一直连接不了.原因正是由于https,不过postman在界面上已经给出了可能的原因和解决 ...

  3. 【转】vscode调试运行c#详细操作过程

    [转]vscode调试运行c#详细操作过程 主要命令: //路径跳转cd //新建项目dotnet new console -o 路径 //运行dotnet run //用于发布exe<Runt ...

  4. centos 配置.Net core 环境并部署dotnet Core文件

    一.配置环境[Microsoft dotnet Core] 1) Add the dotnet product feed sudo rpm -Uvh https://packages.microsof ...

  5. 阿里云centos安装docker

    近期转向core开发,mssql也支持了docker,索性把手上的一台服务改成centos做测试开发.中间安装docker碰到的问题做个记录. docker版本 docker从1.13版本之后采用时间 ...

  6. 「LibreOJ Round #9」CommonAnts 的调和数

    题解: 对于subtask3:可以把相同的归在一起就是$nlogn$的了 对于subtask4: 可以使用高维前缀和的技术,具体的就是把每个质因数看作一维空间 那么时间复杂度是$\sum \limit ...

  7. CyclicBarrier介绍

    应用场景 在某种需求中,比如一个大型的任务,常常需要分配好多子任务去执行,只有当所有子任务都执行完成时候,才能执行主任务,这时候,就可以选择CyclicBarrier了. 实例分析 我们需要统计全国的 ...

  8. Docker 学习4 Docker容器虚拟化网络概述

    一.docker 虚拟化网络概述 1.OVS: OpenVSwitch,不仅能模拟二层网络,还能模拟三层网络,或者VLAN,VXLAN,流控 SDN软件定义网络技术等. 2.overlay netwo ...

  9. 浅谈Java反射

    什么是反射? JAVA反射机制是在运行状态中,对于任意一个类,都能够知道这个类的所有属性和方法:对于任意一个对象,都能够调用它的任意方法和属性:这种动态获取信息以及动态调用对象方法的功能称为java语 ...

  10. jquery只获取自身文本节点,不获取子元素的

    jQuery.text()方法时候,会把子元素的文本也获取到,以下方法可获取自身文本节点,不包括子元素 <div id="demo">只获取我<a href=&q ...