前言

上一篇文章对PHP的一些类型和运算符进行了简单的讲解。PHP入门之类型与运算符

这篇简单讲解一下流程控制。结尾有实例,实例内容是用switch分支和for循环分别做一个计算器和金字塔。

分支控制

单分支控制

if语句 语法如下:

if(表达式){

语句1;

语句2;

...

}

双分支控制

if else语句。语法如下

if(表达式){

语句1;

语句2;

...

}else{

语句1;

语句2;

...

}

如果表达式为真,那么执行{}里面得。如果为假,直接执行else{}里面得语句。

举个例子:

$age=19;
if ($age>18){
echo '你已经成年啦'; #因为$age=19 大于18,所以表达式为真,所以输出后面得。所以输出“你已经成年啦”
}else{
echo '小可爱,你还未成年!';
}

多分支控制

语法:

if(){

语句1;

...

}else if(){

语句1;

...

}else{

语句1;

...

}

这里得else if(){}可以加很多个。

举个例子,比如:

$age=3;
if ($age>18){
echo '你已经成年啦';
}elseif($age>10 && $age<18){
echo '是少年啦';
}elseif($age>5 && $age<10){
echo '你还是个孩子';
}else{
echo '是婴儿啦';
}

多分支还有switch语句。语法如下。

switch(表达式){

case常量1:

break;

case常量2:

break;

case常量3:

break;

case常量4:

break;

...

}

举个例子:

$a=1;
switch ($a){
case 1:
echo '今天星期1';
break;
case 2:
echo '今天星期2';
break;
case 3:
echo '今天星期3';
break;
//这里可以写很多个
default:
echo '输入有误'; }

这里需要注意得是,case语句得break不可以省略,否则无法跳出switch语句,继续向下执行,直到遇到break。还有一点需要注意得是,default语句放在哪里没影响,程序执行顺序是,先查找case语句,case语句没有符合得,在寻找default语句。

区分一下,什么时候用if语句,什么时候用switch语句。

当控制得是一个范围时,一般用if语句,当控制得是每个点时,用switch语句。

循环控制

for循环控制。

语法为for(循环初值;循环得条件;步长){

语句.....

}

举个例子:

for ($age=0;$age<20;$age++){

echo '
这是一个循环';

}

直到循环条件语句为假然后跳出循环。



while循环

循环格式为:

while(循环控制){

循环语句;

}

举个例子:

$a=0;
while ($a<10){ echo '<br/>这是while循环'.$a;
$a++;
}
#循环语句中一定要有控制语句,在这里是$a++,如果不加,0永远小于10,这个一个死循环。

do while循环

循环格式为:

do{

循环语句

}while(循环控制);

举个例子:

$i=0;
do{
echo '<br/>这是一个do while循环'.$i;
$i++;
}while($i<10); 这里也一样,如果不加$i++控制,也会成为死循环。

实例

下面用一个具体的实例,巩固循环流程控制。

switch分支完成简单计算器。

先完成页面的设计,代码如下。

<html>
<head>
<title>这是一个计算器</title>
</head>
<body >
#由于是本地,所以将表单提交到okok.php。
<form action="okok.php" method="post">
<table>
<tr><td>请输入</td><td><input type="text" name="sum1"></td></tr><br/>
<tr><td>请在输入</td><td><input type="text" name="sum2"></td></tr>
<tr><td>点击计算</td><td><input type="submit"></td></tr>
</table>
<select name="oper" >
<option value="+">+</option>
<option value="-">-</option>
<option value="*">*</option>
<option value="/">/</option>
</select>
</form>
</body>
</html>

显示到页面的内容如下



接下来在okok.php中用switch分支进行核心运算。代码如下:

<?php
$sum1=$_POST['sum1'];
$sum2=$_POST['sum2'];
$oper=$_POST['oper'];
$res=0;
switch ($oper){
case "+":
$res=$sum1+$sum2;
break;
case "-":
$res=$sum1-$sum2;
break;
case "*":
$res=$sum1*$sum2;
break;
case "/":
$res=$sum1/$sum2;
break;
default:
echo '运算符不合法';
}
echo '运算结果为:'.$res.'<br/>'; ?>
<a href="mycal.php">返回初页面</a>

现在来运算一下,输入123+456,查看返回结果。

for循环打印金字塔

<?php
#第一层for循环控制金字塔的层数
for ($i=1;$i<=5;$i++){
#控制"*"号
for ($j=1;$j<=$i;$j++){
echo '*';
}
echo '<br/>';
}
?>

显示效果如图



我们发现只是打印了一半的金字塔,如何补全呢?如果我们再控制一下前面每一行的空格和每行的*号是不是就可以了?我们来认证一下。将上面的代码补全。如下:

<?php
#第一层for循环控制金字塔的层数
for ($i=1;$i<=5;$i++){
#控制空格
for ($k=1;$k<=5-$i;$k++){
echo '&nbsp;';
}
#控制"*"号
for ($j=1;$j<=2*$i-1;$j++){
echo '*';
}
echo '<br/>';
}
?>

我们再进阶一下,如果将这个金字塔内部掏空,又该如何实现呢?我们想一下,是不是我们要只要控制好两个边缘的"*"号,其他地方控制填充空格就可以了,有了思路,我们看代码,又补充了哪些地方。看代码:

<?php
#第一层for循环控制金字塔的层数
for ($i=1;$i<=5;$i++){
#控制空格
for ($k=1;$k<=5-$i;$k++){
echo '&nbsp;';
}
#控制"*"号
for ($j=1;$j<=2*$i-1;$j++){
if ($j==1 || $j==2*$i-1){
echo '*';
}else{
#填充空格
echo '&nbsp;';
}
}
echo '<br/>';
}
?>

效果如下图



咱们再进阶一下,如果将这个空心的三角翻转一下,打印出菱形,那么又该如何实现呢?是不是再原来的基础上再控制一下层数、"*"号、空格就可以完成呢。现在咱们看代码。

<?php
#第一层for循环控制金字塔的层数
for ($i=1;$i<=5;$i++) {
#控制空格
for ($k = 1; $k <= 5 - $i; $k++) {
echo '&nbsp;';
}
#控制"*"号
for ($j = 1; $j <= 2 * $i - 1; $j++) {
if ($j == 1 || $j == 2 * $i - 1) {
echo '*';
} else {
#填充空格
echo '&nbsp;';
}
}
echo '<br/>';
}
#翻转
for ($i=5;$i>=0;$i--){
#控制空格
for ($k=0;$k<=5-$i;$k++){
echo '&nbsp;';
}
#控制*和空格
for ($j=1;$j<=2*$i-3;$j++){
if ($j==1 || $j==2*$i-3){
echo '*';
}else{
echo '&nbsp;';
}
}
echo '<br/>';
}
?>

效果如下

小结

简单的说了一下流程控制,希望对大家有帮助。

PHP入门之流程控制的更多相关文章

  1. Python3.7.4入门-2流程控制工具

    2 流程控制工具 记得在语句后加冒号 2.1 while # Fibonacci series: # the sum of two elements defines the next a, b = 0 ...

  2. python语法入门之流程控制

    python语法入门之流程控制 流程控制是指控制流程,具体指控制程序执行的流程. 流程控制分为三种: 1.顺序结构 程序从上而下的正常执行(正常执行的代码就是顺序结构) 2.分支结构 赋予程序人的思维 ...

  3. Python 3 快速入门 2 —— 流程控制与函数

    本文假设你已经有一门面向对象编程语言基础,如Java等,且希望快速了解并使用Python语言.本文对重点语法和数据结构以及用法进行详细说明,同时对一些难以理解的点进行了图解,以便大家快速入门.一些较偏 ...

  4. 04-Python入门学习-流程控制

    一.流程控制if 语法1: if 条件:  code1  code2  code3  .... age=180 height=163 weight=75 sex='female' is_beautif ...

  5. 04 Python入门学习-流程控制(if else elif while for)

    一:流程控制if 语法一: if 条件: code1 code2 code3 ... age = 20 height = 170 weight = 60 sex = 'female' is_beaut ...

  6. python入门之流程控制

    if else 格式: if 条件 command1 command2elif 条件: command3    command4 else: command3 command4 注意条件后和else后 ...

  7. Python入门6 —— 流程控制 - if判断

    代码块: 1.代码块指的是同一级别的代码,在python中用缩进相同的空格数(除了顶级代码块无任何缩进之外,其余代码块都是在原有的基础上缩进4个空格)来标识同一级的代码块 2.同一级别的代码块会按照自 ...

  8. Scala深入浅出实战经典-----002Scala函数定义、流程控制、异常处理入门实战

    002-Scala函数定义.流程控制.异常处理入门实战 Scala函数定义 语句结束无分号 定义无参函数 def 函数名称(参数名称:参数类型)[:Unit=]{ 函数体 } 老师的代码 我的实际代码 ...

  9. python入门篇之介绍和流程控制(一)

    Python入门 一.第一句python代码 很多语言的第一句python代码都是以“你好,世界”开始的,那么我们的python也是如此. 在 /home/dev/ 目录下创建 hello.py 文件 ...

随机推荐

  1. Flask02-Template

    ## 基础使用 $ vim app/templates/index.html > <html> > <head> > <title>{{title ...

  2. jquery入门(1)

    1.jQuery简介 jQuery是一个快速.简洁的JavaScript框架,倡导写更少的代码,做更多的事情 jquery官方网站 jquery中文文档 1.1.简单函数封装 根据id.类名称来获取元 ...

  3. Redis系列(八):发布与订阅

    Redis的发布与订阅,有点类似于消息队列,发送者往频道发送消息,频道的订阅者接收消息. 1. 发布与订阅示例 首先,在本机开启第1个Redis客户端,执行如下命令订阅blog.redis频道: SU ...

  4. 浅谈MySQL数据库基本操作

    数据库配置 通过配置文件统一配置的目的:统一管理 服务端(mysqld) .客户端(client) 配置了 mysqld(服务端) 的编码为utf8,那么再创建的数据库,默认编码都采用utf8 配置流 ...

  5. Spring中使用注解时启用<context:component-scan/>

    在spring中使用注解方式时需要在spring配置文件中配置组件扫描器:http://blog.csdn.net/j080624/article/details/56277315 <conte ...

  6. 第二部分用户交互程序开发,通过paramiko记录ssh会话记录

    需求及任务:实现一个给用户登录的界面(通过ssh登到堡垒机上,然后给它展现一个命令行的页面,然后他选择登哪台机器,一选择就连上去且把日志也记录下来). 先在admin创建几条组数据并与用户关联如下图: ...

  7. node-koa

    什么是koa 基于node.js 平台的下一代web开发框架 async await npm install --save koa npm install --save koa-router ctx. ...

  8. python编程从入门到实践笔记

    我的第一个hello world 程序 print("hello python world") print("hello python world"*3) 打印 ...

  9. When Lambo with Howdoo

    原文链接:https://howdoo.io/when-lambo/ 为了庆祝即将推出的革命性新社交媒体平台Howdoo以及我们令人惊喜的合作伙伴关系和社区,我们正在发起一项竞赛,以最终回答“When ...

  10. 记录一下安装hexo的过程

    记录一下安装hexo的过程 首先你的电脑需要安装node.js和Git 安装好Git之后需要配置本机与Github之间的ssh方便更新同步博客到Github上,在一个地方新建一个文件夹作为我们博客的根 ...