现在的位置: 首页 > 综合 > 正文

2009-10-10项目问题总结__web

2012年08月14日 ⁄ 综合 ⁄ 共 1879字 ⁄ 字号 评论关闭

问题一:
      form表单上下空隙

 程序代码
<form name="xxx" action="xx">
      <table ..>
            <tr>
            ....
            </tr>
      </table>
</form>
为:
<table ..>
      <form name="xxx" action="xx">
            <tr>
                  ....
            </tr>
      </form>
</table>
另一方法:<style>form, select, input { margin: 0px; }</style>

问题二:
      Disabled标识的标签在form里面是无法提交出去的。
Readonly和Disabled的区别 

Readonly和Disabled是用在表单中的两个属性,它们都能够做到使用户不能够更改表单域中的内容。但是它们之间有着微小的差别,总结如下:
Readonly只针对input(text / password)和textarea有效,而disabled对于所有的表单元素都有效,包括select, radio, checkbox, button等。但是表单元素在使用了disabled后,当我们将表单以POST或GET的方式提交的话,这个元素的值不会被传递出去,而readonly会将该值传递出去(这种情况出现在我们将某个表单中的textarea元素设置为disabled或readonly,但是submit button却是可以使用的)。

一般比较常用的情况是:

①在某个表单中为用户预填了某个唯一识别代码,不允许用户改动,但是在提交时需要传递该值,此时应该将它的属性设置为readonly

②经常遇到当用户正式提交了表单后需要等待管理员的信息验证,这就不允许用户再更改表单中的数据,而是只能够查看,由于disabled的作用元素范围大,所以此时应该使用disabled,但同时应该注意的是要将submit button也disabled掉,否则只要用户按了这个按钮,如果在数据库操作页面中没有做完整性检测的话,数据库中的值就会被清除。如果说在这种情况下用readonly来代替disabled的话,若表单中只有input(text / password)和textarea元素,那还是可以的,如果存在其他发元素,比如select,用户可以在重新改写值后按回车键进行提交(回车是默认的submit触发按键)

③我们常常在用户按了提交按钮后,利用javascript将提交按钮disabled掉,这样可以防止网络条件比较差的环境下,用户反复点提交按钮导致数据冗余地存入数据库。

 

问题三:
      让table具有滚动条
用一个div将table 套住,把层的宽和高都设为定长,
<div style="overflow-y:scroll;width:100%;height:100%">
 <table>  
 </table>
</div>
overflow-y不要设置为visible

问题四:
       URL编码:PHP中使用用rawurlencode。弃用urlencode

urlencode:返回字符串,此字符串中除了 -_. 之外的所有非字母数字字符都将被替换成百分号(%)后跟两位十六进制数,空格则编码为加号(+)。此编码与 WWW 表单 POST 数据的编码方式是一样的,同时与 application/x-www-form-urlencoded 的媒体类型编码方式一样。由于历史原因,此编码在将空格编码为加号(+)方面与 RFC1738 编码不同。

      rawurlencode:功能和urlencode基本一样,采用的是RFC1738编码,因此空格会编码为%20。

      就这个唯一的不同把我害惨了。。。。以前的代码都是采用urlencode,从来没有发现过这个问题,结果导致今天出了严重的bug,所有带空格的url都无法解析了。。还是学东西不严谨啊,以后需要加强喽。

结论:
rawurlencode遵守是94年国际标准备忘录RFC 1738,
urlencode实现的是传统做法,和上者的主要区别是对空格的转义是'+'而不是'%20'
javascript的encodeURL也是94年标准,

而javascript的escape是另一种用"%xxx"标记unicode编码的方法。

推荐在PHP中使用用rawurlencode。弃用urlencode

       

抱歉!评论已关闭.