|
|
参考主题:实例学习网页制作中常用的网页表单的应用 4 @% u- B% [2 ^. ]# p6 {
表单的提交
. ~$ Z, L; J% ~7 n4 } 表单的提交
( _6 h6 ]% X, l4 i- E0 u 既然表单是用来采集用户输入的数据,那么,就应该保证用户的数据被准确地提交到预定的地点,也就是说,我们在表单提交的时候,应该对用户的数据进行检验,一来可以避免用户误输数据,二来可以避免用户输入非法的,或者说不合格的数据;检验合格以
! u4 m. \/ o7 }- x: N" l4 B 既然表单是用来采集用户输入的数据,那么,就应该保证用户的数据被准确地提交到预定的地点,也就是说,我们在表单提交的时候,应该对用户的数据进行检验,一来可以避免用户误输数据,二来可以避免用户输入非法的,或者说不合格的数据;检验合格以后,还要保证用户的数据提交到特定的程序。
6 f3 V& }! u; V, h3 \& s 1.数据的检验
7 E! G! V9 S4 ? 数据的检验,通常有两种程序:客户端检验和服务器端检验。客户端检验,比较快,服务器端检验,相对来说比较慢,为了确保安全,通常同时采用,这样就可以避免用户刻意破坏。! J+ F# `+ @% y$ O- i
不管采用什么方式,数据检验的原理都是一样的,一旦用户输入的数据不符合规定,就报错,要求用户重新输入,客户端检验常使用Javascrip脚本,服务器端的视系统而定,本文不对数据检验的具体程序设计进行探讨,仅仅列举几个例子来说明。
5 c4 C" U; ]1 H* W5 o2 L/ n h 样例:必填项,以及简单的数据类型检验
- a9 g4 o" A* F6 K+ r, m 功能实现分析:7 r% f: g" P. d2 L' ?: O$ c
本例给表单添加了onSubmit事件,通过onSubmit="return
$ \5 o, k, d T+ P; W% X4 z CheckDate()"指定提交前,必须通过函数CheckDate()来检验,如果不合格,返回输入数据;
3 E+ V3 K+ h" H% q1 o( a$ w 数据检验的函数如下: <script> function1 F2 L+ w7 t+ U& \' P, m4 b1 c2 B0 A
CheckDate(){ //取得输入的数据 userName = document.RedForm.userName.value;
0 b: a7 G9 ^9 K* H userEmail = document.RedForm.userEmail.value; //如果没有输入姓名 if
2 r& b# H/ p( X3 U (userName=="") { alert("请输入姓名"); document.RedForm.userName.focus();
) v' h7 ]# B+ }* T& G. t& q/ j9 K4 ` return false; }else{ //如果没有输入Email,上海搬场公司或者Email地址错误(不含@) if
- ?; p- c" }; D. _+ u) l9 w/ ? ((userEmail=="")||(userEmail.indexOf("@")==-1)) {
" k" f: I- ] P" ? alert("请重新输入Email地址"); document.RedForm.userEmail.focus(); return: P% k9 R& ~( y+ s6 {4 _- v
false; }else return true; } }
3 X* @$ K2 I7 E, |/ ?1 g </script>& D7 u2 F; V% h
以下带*的必须输入:7 _6 \' p( n' V2 S1 S3 M |
姓名: *2 X5 I& g* t# S* a
Email: *
8 Z- ~8 U( s- O- q. l. Y 表单的分支提交6 v# Y- _5 e# ~& R) [
有的时候http://www.zyldjd.com/,大众搬家表单需要根据用户的选择,提交到不同的程序,怎么做呢?通过脚本来检测用户的选择分支,从而向不同的程序提交表单,看看样例:
4 r" U! w: B/ F5 q 样例:分支提交
. g) _& z& @+ v1 I5 h 用户名: 密码:8 l% m" Z# i1 m; l
公司用户 个人用户
9 t: A. v* J3 r3 `+ t 功能实现分析:) b& Z9 h$ }3 j& @2 q6 A
这里首先用到的是form的onSubmit="TwoSubmit(this)"' f# u6 w, i6 F2 h' P* w7 ]2 C+ L
然后根据选择的分支http://www.sh6997.comhttp://www.xiangpaiming.com,上海搬家公司来分别递交到不同的程序,大众搬场TwoSubmit()函数如下:! w0 N4 b8 y, g% y, q
<script> function TwoSubmit(form){ if+ A9 ]1 G# l K8 ?
(form.Ref[0].checked){ form.action = "cop.asp";//这里是分之一 }else{
3 Q3 b# c% Q$ y5 \( d; J8 o2 M form.action = "ind.asp";//这里是分之二 } form.submit(); }/ u5 v9 ]5 t$ O
</script>
4 j) N* I5 T/ |* b/ P3 w 用任何元素提交表单
9 m5 p7 X) H! I6 L, d; h$ ~; j 是不是只有按钮或者图片按钮才能提交表单呢?当然不是,实际上,任何页面元素都可以提交表单,不过嘛,都是通过脚本来完成的,下面我们就使用链接来代替Submit按钮:* R* @# Y9 M6 z# t& \: U2 b+ [ }
[恶搞]表格中单元格之间分隔线的隐藏方法_ |
|