|
|
参考主题:实例学习网页制作中常用的网页表单的应用
& Z& V5 l6 e; W' a! ~; _1 g 表单的提交& X! l3 i$ d" J+ w2 d- D8 P7 ^
表单的提交
/ h8 g" P8 n( J. W- j. T3 W4 q 既然表单是用来采集用户输入的数据,那么,就应该保证用户的数据被准确地提交到预定的地点,也就是说,我们在表单提交的时候,应该对用户的数据进行检验,一来可以避免用户误输数据,二来可以避免用户输入非法的,或者说不合格的数据;检验合格以; U4 B+ y) \8 [7 P4 |4 ]9 F
既然表单是用来采集用户输入的数据,那么,就应该保证用户的数据被准确地提交到预定的地点,也就是说,我们在表单提交的时候,应该对用户的数据进行检验,一来可以避免用户误输数据,二来可以避免用户输入非法的,或者说不合格的数据;检验合格以后,还要保证用户的数据提交到特定的程序。3 _3 r3 ]" G1 E
1.数据的检验
# ~5 g5 F/ w) b5 W9 j' z! ~ 数据的检验,通常有两种程序:客户端检验和服务器端检验。客户端检验,比较快,服务器端检验,相对来说比较慢,为了确保安全,通常同时采用,这样就可以避免用户刻意破坏。! J) k& w4 ]- k- a5 T: D) s# ^
不管采用什么方式,数据检验的原理都是一样的,一旦用户输入的数据不符合规定,就报错,要求用户重新输入,客户端检验常使用Javascrip脚本,服务器端的视系统而定,本文不对数据检验的具体程序设计进行探讨,仅仅列举几个例子来说明。
! {# o2 Z/ Y8 Z7 q 样例:必填项,以及简单的数据类型检验
! V: g* N, t$ G; y! b 功能实现分析:
: b3 U Q& o4 S& ? 本例给表单添加了onSubmit事件,通过onSubmit="return) F5 @: S6 C7 q# o% g9 X2 y
CheckDate()"指定提交前,必须通过函数CheckDate()来检验,如果不合格,返回输入数据;4 J q+ p9 Y- Z: e
数据检验的函数如下: <script> function
, W7 U7 u" s- w/ T3 S$ Z9 S% E) r CheckDate(){ //取得输入的数据 userName = document.RedForm.userName.value; |( N7 J) Y& C3 X0 u
userEmail = document.RedForm.userEmail.value; //如果没有输入姓名 if2 f6 O( b4 F3 r) n5 w
(userName=="") { alert("请输入姓名"); document.RedForm.userName.focus();$ M1 ?( F d6 b. W# s
return false; }else{ //如果没有输入Email,上海搬场公司或者Email地址错误(不含@) if
7 {- G4 M: J+ S" v* v7 q ((userEmail=="")||(userEmail.indexOf("@")==-1)) {
4 a+ A/ V5 X/ c! o( t1 ^: R alert("请重新输入Email地址"); document.RedForm.userEmail.focus(); return5 H3 F1 {9 i& F) X6 ~; o2 c+ h
false; }else return true; } }
* Z) o" H7 l2 c9 p </script>
0 v6 _& {- s$ b: p9 o 以下带*的必须输入:
% O; D# J/ p5 s- H6 c1 `8 \; M 姓名: *
- A; B) _% Z& o' K- m Email: *. d0 p; d& }/ i( `
表单的分支提交
# b, s% Y3 B& Z2 L; I6 O9 { 有的时候http://www.zyldjd.com/,大众搬家表单需要根据用户的选择,提交到不同的程序,怎么做呢?通过脚本来检测用户的选择分支,从而向不同的程序提交表单,看看样例:5 V! {, a' D$ B6 L/ ^, K Z- D# L
样例:分支提交6 a1 {; [3 X! L' b7 z
用户名: 密码:2 a- ?$ M6 k0 o+ G. \0 _9 F5 B
公司用户 个人用户
; Z4 B4 j. I" i+ d1 H3 y3 F 功能实现分析:
6 K% D/ j) J, x( R/ F0 V) O 这里首先用到的是form的onSubmit="TwoSubmit(this)"# P. Q7 X5 J$ i" x& G$ A" _7 n
然后根据选择的分支http://www.sh6997.comhttp://www.xiangpaiming.com,上海搬家公司来分别递交到不同的程序,大众搬场TwoSubmit()函数如下:
6 }- x9 G! L1 J <script> function TwoSubmit(form){ if
; t) O3 l% @7 a$ p5 O4 U (form.Ref[0].checked){ form.action = "cop.asp";//这里是分之一 }else{5 i3 n6 F! o. w. [6 \; L2 C
form.action = "ind.asp";//这里是分之二 } form.submit(); }
- V' j [ I5 m& a </script>, r3 m8 R' d1 t# R# K1 n/ ]2 l+ h
用任何元素提交表单) v* [* }! d" t2 {/ G9 N3 R
是不是只有按钮或者图片按钮才能提交表单呢?当然不是,实际上,任何页面元素都可以提交表单,不过嘛,都是通过脚本来完成的,下面我们就使用链接来代替Submit按钮:8 R( p. v& H# c7 [/ o. h8 J
[恶搞]表格中单元格之间分隔线的隐藏方法_ |
|