有时候会发送空白表单到客户那,因为啥都没填直接submit掉。哎,多不好。
介绍2个函数,isset和empty。isset对赋值后的变量返回true,不论赋的什么值,空string也是true;empty当里面的参数是空值是返回true;
空值有null,'',0,false.
这样就不会就能再用户提交空的东西的时候做出响应了。照理来说应该在客户端用js先去处理,再PHP处理,php作为最后一道墙检验。
假如提交过来东西有问题,就用类似这样的if循环去判断掉
判断掉之后,万一出错呢,还要回显一张表单给客户重填把。
就直接用html代码了
<?php
if(out_false){
?>
<form action="<?php echo $_SERVER[PHP_SELF]?>" method="post">
<input type="text" name="user" value="<?php echo $user ?>">
<input type="pasword" name="password" value=<?php echo $password?>>
<input type="submit" value="submit"/>
</form>
<?php
}
?>
<?php?>外面的都是html代码了,但是form表单部分还是在if逻辑里面的,还有这个东西$_SERVER[PHP_SELF],可以引用前台提交过来的表单的url。假如表单数据填写有误,直接返回一个表单,这个返回的表单记录这之前填的东西。<?php echo $password?> 直接用php代码把传过来的东西再输到表单上,不过这次的表单地址url是.php结尾的了,要注意下。
另外,可以用isset($_POST['submit'])判断表单是否提交,点了submit,就有一个值传到这个超级全局变量中了,isset就是true了。
另外,数据库中我们必须让表的每一行数据具有唯一性。这就用到了主键这个东西。这就要改数据表了,总不能直接drop table 掉把。。。
alter table 表名 add id int not null auto_increment first,add primary key(id)
大意就是添加id,Int类型,不能为空,每次自己增加1,放在第一列,添加为主键,(每个表只有一个主键滴);这样每一行数据就唯一了。
唯一的主键干嘛用呢?明天再看再写。嘿嘿,要劳逸结合。
接上篇。
主键用来标志每一行,给每个表单字段加上一个复选框,再name设为todelete[],value设为主键,传到后台$_POST['todelete']就是一个数组,数组的项就是value值,也就是主键。
这样就可以用来删主键对应的行了。