PHP 和 HTML


Posted in PHP onOctober 09, 2006

PHP 和 HTML
PHP 和 HTML 可以互操作: PHP 能够生成 HTML, 而 HTML 可以传递信息给 PHP. 1. 我用一个 form/URL传值时,我要怎样 编码/解码? 2. 我在用 <input type="image"> 标记, 但 $foo.x and $foo.y 变量却不可用. 它们在哪里? 3. 我怎样创建 HTML <form>数组? 4. 我怎样从一个多选框得到所有的结果值?
1. 我用一个 form/URL传值时,我要怎样 编码/解码?
在几个阶段里,编码是非常重要的. 假设你有一个 字符串变量 $data, 它包含一些你要以 未编码 方式传递的字符, 要经过下面阶段的编码:

HTML 解释. 为了表示任何一个字符串, 你必须 把它包含在双引号里, 而且是HTML特殊字符的要使用 htmlspecialchars写法.
URL: URL 由几部分组成. 你想你的数据被看成URL的一部分, 你 必须 用 urlencode()编码它.

例 52-1. 隐藏的 HTML 表单元素 <?php    echo "<input type=hidden value=\"" . htmlspecialchars($data) . "\">\n";?>
注意: 这里不能用urlencode() $data, 因为 urlencode() 数据是浏览器的责任. 绝大多数浏览器可以正确处理这样的数据. 无论用何种方法( GET POST). 你可以只考虑 GET 请求, 因为 POST 请求通常被隐藏了.
例 52-2. 用户编辑数据 <?php    echo "<textarea name=mydata>\n";    echo htmlspecialchars($data)."\n";    echo "</textarea>";?>
注意: 在浏览器窗口显示的数据会被解码成可读的,因为浏览器会对 HTML 标记进行解释.
一旦提交, 无论GET 还是 POST, 浏览器在传输数据时会进行URL编码,PHP则会对它进行解码. 一切都是自动进行的,你不需要做什么.
例 52-3. 在URL串里 <?php    echo "<a href=\"" . htmlspecialchars("/nextpage.php?stage=23&data=" .        urlencode($data)) . "\">\n";?>
注意: 实际上你在自己写一个 GET 请求, 所以用urlencode() 对它进行编码就是不可缺少的.
注意: 你需要htmlspecialchars() 整个URL串, 因为URL串是 HTML-属性的一部分. 这种情况下, 浏览器首先 反-htmlspecialchars() 这个值, 然后送出 URL . PHP 会识别这个URL串, 因为你用 urlencoded() 对它进行了编码.
你会发现 & 在 URL 串中 被替换成 &. 虽然你没有编码大部分的浏览器也会帮你做,但并不是所有的都能. 所以即使你在写一个静态的URL,你也需要 用 htmlspecialchars() 来对 URL 进行编码.

2. 我在用 <input type="image"> 标记, 但 $foo.x and $foo.y 变量却不可用. 它们在哪里?
在提交一个表单里, 可能使用一个 image 控件而不是使用 标准的提交按钮: <input type="image" src="image.gif" name="foo">When 当用户点上 image 控件的某个地方时, 表单被提交到服务器,并有两个附加的变量: foo.x and foo.y.
因为 $foo.x 和 $foo.y 在 PHP 里是无效的变量名, 所以它们自动被转换成$foo_x and $foo_y. 也就是说, 圆点被替换成了下划线.
3. 我怎样创建 HTML <form>数组?
为了使你的表单结果作为数组送往PHP脚本,你可以给 <input>, <select> or <textarea> 元素象下面这样取名: <input name="MyArray[]"><input name="MyArray[]"><input name="MyArray[]"><input name="MyArray[]">注意元素名后面的中括号不能省, 就是它使结果成为一个数组. 你可以通过元素名把它们排成不同的数组 : <input name="MyArray[]"><input name="MyArray[]"><input name="MyOtherArray[]"><input name="MyOtherArray[]">上面的代码产生了两个数组, MyArray 和 MyOtherArray, 送往PHP. 当然也可以为你的数组指明键值: <input name="AnotherArray[]"><input name="AnotherArray[]"><input name="AnotherArray[email]"><input name="AnotherArray[phone]">AnotherArray 数组会容纳下标 0, 1, email and phone.

说明: 在元素名里标明下标值是可选的.如果你没有标明,数组会按元素在表单里出现的顺序来依次填充. 如我们的头一个例子里数组的下标分别是: 0, 1, 2 and 3.

参见 Array 函数 and PHP外部变量.
4. 我怎样从一个多选框得到所有的结果值?
HTML里的多选框是用来让用户从列表里选多个值的.这些值然后被送往表单的处理脚本. 问题在于它们都有同样的变量名. 例如: <select name="var" multiple>每一个被选择的项会这样传值给处理脚本: var=option1var=option2var=option3每个值覆盖了前一项的值. $var 解决办法是使用 PHP的 "表单元素数组"特性.下面就是: <select name="var[]" multiple>PHP会把 $var当成一个数组.每个被选择项都会分配给一个数组单元. 第一项是$var[0], 下一项是 $var[1], 依此类推. count() 函数可以用来判断数组有多少选择项 ,如果有必要的话,还可以用 sort() 函数来对数组进行排序.
如果你在使用 JavaScript , 直接使用元素名引用可能会出错. 你应该使用它的数字索引,或者把变量名放在单引号之内.例如: variable = documents.forms[0].elements['var[]'];

PHP 相关文章推荐
php环境配置 php5 MySQL5 apache2 phpmyadmin安装与配置图文教程
Mar 16 PHP
PHP的分页功能
Mar 21 PHP
PHP与MySQL开发的8个技巧小结
Dec 17 PHP
php数组函数序列之asort() - 对数组的元素值进行升序排序,保持索引关系
Nov 02 PHP
PHP的preg_match匹配字符串长度问题解决方法
May 03 PHP
PHP 实现类似js中alert() 提示框
Mar 18 PHP
PHP实现WebService的简单示例和实现步骤
Mar 27 PHP
PHP模板引擎smarty详细介绍
May 26 PHP
PHP实现超简单的SSL加密解密、验证及签名的方法示例
Aug 28 PHP
PHP文件管理之实现网盘及压缩包的功能操作
Sep 20 PHP
PHP设计模式之适配器模式原理与用法分析
Apr 25 PHP
php中Swoole的热更新实现代码实例
Mar 04 PHP
数据库相关问题
Oct 09 #PHP
编译问题
Oct 09 #PHP
PHP 和 COM
Oct 09 #PHP
如何获得PHP相关资料
Oct 09 #PHP
VML绘图板②脚本--VMLgraph.js、XMLtool.js
Oct 09 #PHP
example1.php
Oct 09 #PHP
一个ftp类(ini.php)
Oct 09 #PHP
You might like
老照片 - 几十年前的收音机与人
2021/03/02 无线电
基于php split()函数的用法详解
2013/06/05 PHP
解析php中反射的应用
2013/06/18 PHP
ThinkPHP框架任意代码执行漏洞的利用及其修复方法
2014/07/04 PHP
ThinkPHP实现支付宝接口功能实例
2014/12/02 PHP
PHP实现浏览器中直接输出图片的方法示例
2018/03/14 PHP
laravel orm 关联条件查询代码
2019/10/21 PHP
免费空间广告万能消除代码
2006/09/04 Javascript
Jquery 设置标题的自动翻转
2009/10/03 Javascript
JS定时器实例
2013/04/17 Javascript
JS实现让网页背景图片斜向移动的方法
2015/02/25 Javascript
jQuery 获取多选框的值及多选框中文的函数
2016/05/16 Javascript
完美实现八种js焦点轮播图(上篇)
2016/07/18 Javascript
Angularjs手动解析表达式($parse)
2016/10/12 Javascript
AngularJS之自定义服务详解(factory、service、provider)
2017/04/14 Javascript
webpack配置的最佳实践分享
2017/04/21 Javascript
vue使用stompjs实现mqtt消息推送通知
2017/06/22 Javascript
解析Vue.js中的组件
2018/02/02 Javascript
vue项目中锚点定位替代方式
2019/11/13 Javascript
JS document文档的简单操作完整示例
2020/01/13 Javascript
vue实现短信验证码输入框
2020/04/17 Javascript
js实现省级联动(数据结构优化)
2020/07/17 Javascript
用Python实现QQ游戏大家来找茬辅助工具
2014/09/14 Python
wxPython修改文本框颜色过程解析
2020/02/14 Python
Django choices下拉列表绑定实例
2020/03/13 Python
对python pandas中 inplace 参数的理解
2020/06/27 Python
Python+Dlib+Opencv实现人脸采集并表情判别功能的代码
2020/07/01 Python
浅谈keras中的keras.utils.to_categorical用法
2020/07/02 Python
python3从网络摄像机解析mjpeg http流的示例
2020/11/13 Python
解决PDF 转图片时丢文字的一种可能方式
2021/03/04 Python
使用CSS3制作倾斜导航条和毛玻璃效果
2017/09/12 HTML / CSS
CSS3媒体查询(Media Queries)介绍
2013/09/12 HTML / CSS
护理人员的自我评价分享
2014/03/15 职场文书
新学期红领巾广播稿
2014/10/04 职场文书
2015年行政部工作总结
2015/04/28 职场文书
售房协议书范本
2015/08/11 职场文书