打算看《php和mysql web开发》来学习php,所以也算是这本书的学习笔记吧,也按照书里的例子来练习,但是也有些取舍。第一章是一个订单表单的例子,php用于处理提交的表单。

  1.先创建订单表单orderform.html:

  代码如下:

<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
</head>
<body>
<form action="processorder.php" method="post">
<table>
<tr style="background-color:#ccc">
<td width="100">种类</td>
<td>数量</td>
</tr>
<tr>
<td>轮胎</td>
<td><input type="text" name="tireqty" size="3"></td>
</tr>
<tr>
<td>汽油</td>
<td><input type="text" name="oilqty" size="3"></td>
</tr>
<tr>
<td>火花塞</td>
<td><input type="text" name="sparkqty" size="3"></td>
</tr>
<tr>
<td colspan="2" align="center">
<input type="submit" value="submit order">
</td>
</tr>
</table>
</form>
</body>
</html>

  2.再创建procssorder.php来处理表单。 

  1)添加一点动态内容,显示表单的处理时间:

    php的注释有多行注释/*... */,单行注释//或#。

    php有4种风格的标记:
     XML风格   <?php code ?>
      简短风格    <? code ?>
      script风格  <script language="php">code</script>
      asp风格     <% code %>
      推荐使用xml风格,简短风格和asp风格需要在配置文件中启用相应的选项。

<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>订单处理页</title>
</head>
<body>
<h1>汽车配件网店</h1>
<h2>订单</h2>
<?php
echo "<p>订单处理时间:".date("H:i, jS F Y")."</p>"; //php用“.”连接字符串
?>
</body>
</html>

  2)访问表单变量。

  在php中可以通过如下三种方式访问tireqty域的值:

  $tireqty                                 //简短风格

   $_POST['tireqty']                    //中等风格

   $HTTP_POST_VARS['tireqty']   //冗长风格   

  简短风格需要将register_gloabals配置选项设置为on,这可能会导致安全性问题的错误,所以不建议用这种方式。冗长风格已经被弃用,通过register_long_arrays配置禁用它可以改进性能。所以中等风格是如今所推荐的。

  中等风格包括从$_POST, $_GET或$_REQUEST数组中检索变量。$_GET或$_POST保存相应的表单提交方式的数据,$_REQUEST保存了所有提交方式的表单数据。

<?php
//php每一行要用;结尾
$tireqty = $_POST['tireqty'];
$oilqty = $_POST['oilqty'];
$sparkqty = $_POST['sparkqty'];
?>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>订单处理页</title>
</head>
<body>
<h1>汽车配件网店</h1>
<h2>订单</h2>
<?php
echo "<p>订单处理时间:".date("H:i, jS F Y")."</p>"; //php用“.”连接字符串
echo "<p>您的订单如下:</p>";
echo $tireqty." 个轮胎<br>";
echo $oilqty." 桶汽油<br>";
echo "$sparkqty 个火花塞"; //简单类型的变量可以直接写在双引号中,php会用变量的内容插入到字符串中,单引号没有这个特性。
?>
</body>
</html>

  3)计算购买的数量和总价。

  php变量不需要提前声明,变量名前面必须加$。

  常量用define函数定义,并且引用常量的时候前面没有$符号。

  define('TIREPRICE', 100);

   echo TIREPRICE;

<?php
//php每一行要用;结尾
$tireqty = $_POST['tireqty'];
$oilqty = $_POST['oilqty'];
$sparkqty = $_POST['sparkqty'];
$totalqty = 0;
$totalamount = 0.00; define('TIREPRICE', 100);
define('OILPRICE', 10);
define('SPARKPRICE', 4); $totalqty = $tireqty + $oilqty + $sparkqty;
$totalamount = $tireqty * TIREPRICE + $oilqty * OILPRICE + $sparkqty * SPARKPRICE;
?>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>订单处理页</title>
</head>
<body>
<h1>汽车配件网店</h1>
<h2>订单</h2>
<?php
echo "<p>订单处理时间:".date("H:i, jS F Y")."</p>"; //php用“.”连接字符串
echo "购买总数:$totalqty <br>";
echo "购买总额:¥$totalamount<br>";
?>
</body>
</html>

  4)加上简单的服务器端验证。

  可以用exit结束整个php脚本的执行。

  empty()可以检查变量是否为空或0,is_numeric()可以检查变量是否为数字或数字字符串。

<?php
//php每一行要用;结尾
$tireqty = $_POST['tireqty'];
$oilqty = $_POST['oilqty'];
$sparkqty = $_POST['sparkqty'];
$totalqty = 0;
$totalamount = 0.00; define('TIREPRICE', 100);
define('OILPRICE', 10);
define('SPARKPRICE', 4); ?>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>订单处理页</title>
</head>
<body>
<h1>汽车配件网店</h1>
<h2>订单</h2>
<?php
if(empty($tireqty) && empty($oilqty) && empty($sparkqty)){
echo "<p style='color:red'>您没有选购商品</p>";
exit;
}
if(is_numeric($tireqty) && is_numeric($oilqty) && is_numeric($sparkqty)){ $totalqty = $tireqty + $oilqty + $sparkqty;
$totalamount = $tireqty * TIREPRICE + $oilqty * OILPRICE + $sparkqty * SPARKPRICE; echo "<p>订单处理时间:".date("H:i, jS F Y")."</p>"; //php用“.”连接字符串
echo "购买总数:$totalqty <br>";
echo "购买总额:¥$totalamount<br>";
}else{
echo "<p style='color:red'>参数必须为数字</p>";
exit;
}
?>
</body>
</html>

  3.大功告成:

  

  

  

【自学php】第二天 - php快速入门的更多相关文章

  1. RabbitMQ学习总结 第二篇:快速入门HelloWorld

    目录 RabbitMQ学习总结 第一篇:理论篇 RabbitMQ学习总结 第二篇:快速入门HelloWorld RabbitMQ学习总结 第三篇:工作队列Work Queue RabbitMQ学习总结 ...

  2. 第二章 Vue快速入门-- 28 自定义按键修饰符

    事件处理-按键修饰符 js 里面的键盘事件对应的键码 <!DOCTYPE html> <html lang="en"> <head> <m ...

  3. 第二章 Vue快速入门-- 27 字符串的padStart方法使用

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="utf-8&quo ...

  4. 第二章 Vue快速入门-- 26 过滤器-定义私有过滤器

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="utf-8&quo ...

  5. 第二章 Vue快速入门-- 25 过滤器-定义格式化时间的全局过滤器

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="utf-8&quo ...

  6. 第二章 Vue快速入门-- 23 品牌案例-根据关键字实现数组的过滤

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="utf-8&quo ...

  7. 第二章 Vue快速入门--20 品牌案例-完成品牌列表的添加功能+ 21 品牌案例-根据Id完成品牌的删除

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="utf-8&quo ...

  8. 第二篇 CSS快速入门

    学CSS 和 JS的路线: 1. 首先,学会怎么找到标签.只有找到标签,才能操作标签——CSS通过选择器去找标签 2. 其次,学会怎么操作标签对象. CSS概述 CSS是Cascading Style ...

  9. 第二章 Vue快速入门--14 使用v-model实现计算器的案例

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="utf-8&quo ...

随机推荐

  1. AJAX验证数据库内容并显示在页面

    功能实现: 在jsp页面中填写文本框内容,光标离开文本框,在本页面的相应地方获取数据库中改值所对应的其他数据. servlet: request.setCharacterEncoding(" ...

  2. MYSQL 插入二进制数的 2 种方法。

    方法 1.insert into TableName set column =''; 方法 2.insert into TableName .... values(.....); ---------- ...

  3. nginx请求体读取(二)

    2,丢弃请求体 一个模块想要主动的丢弃客户端发过的请求体,可以调用nginx核心提供的ngx_http_discard_request_body()接口,主动丢弃的原因可能有很多种,如模块的业务逻辑压 ...

  4. 好久没来了,重出江湖,共享个python34+pyqt+pyserial串口工具源码

    真的是好久没来了,写博客对我来说还真是难坚持下来,热度一过就忘了,就算什么时候想起来也懒得去敲一个字,这次真不知道能坚持多久,随心吧,想写写,不想写也不勉强自己. 最近由于工作调试需要自己写了一个带图 ...

  5. javascript模式

    http://developer.51cto.com/art/201212/372725.htm http://justjavac.com/javascript/2012/12/14/model-vi ...

  6. 利用COM组件IPicture读取jpg、gif、bmp图片文件数据和显示图片

    1.读取图片数据 函数原型:bool LoadImage(const char *pName, unsigned char *pBitData); 函数功能,读取pName指向的图片文件的位图数据 b ...

  7. wikioi1688 求逆序对

    题目描述 Description 给定一个序列a1,a2,…,an,如果存在i<j并且ai>aj,那么我们称之为逆序对,求逆序对的数目 数据范围:N<=105.Ai<=105. ...

  8. Curly braces in Python in 2012? - Stack Overflow

    Curly braces in Python in 2012? - Stack Overflow Curly braces in Python in 2012? [closed]

  9. 把DEDE的在线文本编辑器换成Kindeditor不显示问题

    在织梦论坛下载了[Kindeditor编辑器For DedeCMS],按照操作说明安装后,后台文章编辑的区域却显示空白,有人说不兼容V57版本,有人说不兼容gbk版本,我也纠结了很久,在网上找了很多版 ...

  10. 设置ListView的item多选

    一,首先定义一个类来关联Adapter和Activity能够记住点击的位置 public class MyViewHoler{ public CheckBox cb; public TextView ...