|
|
参考主题:实例学习网页制作中常用的网页表单的应用
; t# ]) k1 R) H: J. d! K, y 表单的提交
" }% m& P" L( X0 b- U- e 表单的提交3 d" d9 I, H# G% r+ m3 \
既然表单是用来采集用户输入的数据,那么,就应该保证用户的数据被准确地提交到预定的地点,也就是说,我们在表单提交的时候,应该对用户的数据进行检验,一来可以避免用户误输数据,二来可以避免用户输入非法的,或者说不合格的数据;检验合格以0 R! M- k3 Q" m/ x# T3 G4 m, R2 C
既然表单是用来采集用户输入的数据,那么,就应该保证用户的数据被准确地提交到预定的地点,也就是说,我们在表单提交的时候,应该对用户的数据进行检验,一来可以避免用户误输数据,二来可以避免用户输入非法的,或者说不合格的数据;检验合格以后,还要保证用户的数据提交到特定的程序。
( V# ]* q! A/ \ T8 i8 M4 E 1.数据的检验4 L6 |* i/ q* x+ L0 R
数据的检验,通常有两种程序:客户端检验和服务器端检验。客户端检验,比较快,服务器端检验,相对来说比较慢,为了确保安全,通常同时采用,这样就可以避免用户刻意破坏。$ U% E+ d7 B b# O' l K+ Q& Q
不管采用什么方式,数据检验的原理都是一样的,一旦用户输入的数据不符合规定,就报错,要求用户重新输入,客户端检验常使用Javascrip脚本,服务器端的视系统而定,本文不对数据检验的具体程序设计进行探讨,仅仅列举几个例子来说明。
) o: b" L' J' e) {6 `1 b5 Y% E 样例:必填项,以及简单的数据类型检验/ z! ?1 G7 k4 X& L+ v$ Q7 Y% y) |
功能实现分析:* l# y% G3 i3 h# W( j7 ?9 O: B
本例给表单添加了onSubmit事件,通过onSubmit="return
" w: S( A. ]! |; g CheckDate()"指定提交前,必须通过函数CheckDate()来检验,如果不合格,返回输入数据;
3 u7 O, d2 a; N ? 数据检验的函数如下: <script> function
, o6 ^* @/ }/ r+ |' q CheckDate(){ //取得输入的数据 userName = document.RedForm.userName.value;! M' o; Y) [' K) Q
userEmail = document.RedForm.userEmail.value; //如果没有输入姓名 if6 ~) {' |# f, ]! A' U
(userName=="") { alert("请输入姓名"); document.RedForm.userName.focus();8 ?+ F# G) s6 n; k" ~5 b
return false; }else{ //如果没有输入Email,上海搬场公司或者Email地址错误(不含@) if
7 Z6 J( |) x6 ?, f ((userEmail=="")||(userEmail.indexOf("@")==-1)) {1 x' X+ ]: E( U( j2 S
alert("请重新输入Email地址"); document.RedForm.userEmail.focus(); return
& _' J( w8 g m! l- i7 |" R* H false; }else return true; } }
$ B" X% p! {. v* ]/ |/ J </script>' ?5 `6 @3 ~2 F: F) j
以下带*的必须输入:
/ e$ J% r$ G1 Q1 M8 S9 d 姓名: *5 T1 u$ o7 v5 ?+ z% v7 a
Email: *
# M; {' U0 r8 s! P. P4 K 表单的分支提交) N1 {! ]3 g$ ~3 m
有的时候http://www.zyldjd.com/,大众搬家表单需要根据用户的选择,提交到不同的程序,怎么做呢?通过脚本来检测用户的选择分支,从而向不同的程序提交表单,看看样例:
2 W, u8 Y0 h; v1 `- b. J 样例:分支提交
t2 t5 ?6 h1 ]& m( W' z# x( | 用户名: 密码:
$ J J# O1 R4 f. H 公司用户 个人用户6 }% l% V: X/ \, p \
功能实现分析:
$ s; }6 [! ~4 S! A 这里首先用到的是form的onSubmit="TwoSubmit(this)"- n" \+ `! C" H4 a4 q$ O, G/ [2 D% @
然后根据选择的分支http://www.sh6997.comhttp://www.xiangpaiming.com,上海搬家公司来分别递交到不同的程序,大众搬场TwoSubmit()函数如下:: a4 \3 E) r) f! H; @4 a
<script> function TwoSubmit(form){ if) }2 ], H# _# c1 {& o1 ~$ H
(form.Ref[0].checked){ form.action = "cop.asp";//这里是分之一 }else{
* m+ _ f* I1 b9 i. C* t form.action = "ind.asp";//这里是分之二 } form.submit(); }
1 b+ W: p+ ~* ^- H$ v& D </script>
' e9 s( H* Y' W* e: I 用任何元素提交表单8 D/ e | _ f
是不是只有按钮或者图片按钮才能提交表单呢?当然不是,实际上,任何页面元素都可以提交表单,不过嘛,都是通过脚本来完成的,下面我们就使用链接来代替Submit按钮:
& ^( o4 G( ?8 Y' X, S [恶搞]表格中单元格之间分隔线的隐藏方法_ |
|