打算看《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. jq插件第二款来袭 图片滚动

    这第二款也是非常实用的插件,也是与图片相关,关于图片的需求太多了,这个是图片滚动哦,不过不是无缝滚动,是左像右滚动,到头的话再往回滚动,利用scrollLeft实现的,支持自动滚动和每次滚动的个数默认 ...

  2. java.lang.RuntimeException: Unable to start activity ComponentInfo{com.ex.activity/com.ex.activity.LoginActivity}: android.view.InflateException: Binary XML file line #1: Error inflating class

    java.lang.RuntimeException: Unable to start activity ComponentInfo{com.ex.activity/com.ex.activity.L ...

  3. python-整理--使用IDE

    如何使用python的IDE 安装好python3.4之后,默认有一个叫IDLE,就是目录lib/idlelib之下,是一个简单实用的工具. 在VS2013上安装一个插件就可以使用VS当IDE了.插件 ...

  4. 如何处理JS与smarty标签的冲突

    smarty的默认标记符是大括号:{}, 假如我们页面上有JS且定义了函数或者对象,或者有CSS定义了样式,就会出现大括号, smary引擎就会把这些大括号当作smarty语法来解释, 很明显,这些C ...

  5. Sum Problem-hdu-1001

    Hey, welcome to HDOJ(Hangzhou Dianzi University Online Judge). In this problem, your task is to calc ...

  6. MVC4商城项目一:框架设计

    代码已托管在  https://code.csdn.net/denghao156/ktnmb_mvc4 先上图,设计模式参考:ddmvc4.codeplex.com 一.unintofwork  设计 ...

  7. SQL Server 性能篇- 碎片

    本文分为两个问题: 第一,碎片是什么:第二,碎片怎么处理: 现在,来找解决这两个问题:  一.碎片是什么 说到碎片,就要提到索引了,索引用着挺爽的啊!是的,一旦索引建立,我们搜索数据的效率就提高了:然 ...

  8. Oracle EBS-SQL (BOM-19):主BOM与替代BOM互换.sql

    替代BOM与主BOM互相转换 BOM: 1-01-27-211       子件:1-01-27-416  ID:2202 BOM替代项:替代0001   子件: 1-01-26-204   ID:2 ...

  9. WorkFlow4.0--入门到精通系列-专题索引

    原文地址:http://www.cnblogs.com/hegezhou_hot/archive/2011/06/15/2081405.html 开篇 首先.非常感谢大家的支持和厚爱,才有了这个系列, ...

  10. ACM计算几何题目推荐

    //第一期 计算几何题的特点与做题要领: 1.大部分不会很难,少部分题目思路很巧妙 2.做计算几何题目,模板很重要,模板必须高度可靠. 3.要注意代码的组织,因为计算几何的题目很容易上两百行代码,里面 ...