|
|
参考主题:实例学习网页制作中常用的网页表单的应用 * d4 c1 @1 G1 n' j/ r* l" a
表单的提交. e& Y7 m$ R% j1 [5 \
表单的提交1 O- O: B8 m( X( `* n. `0 D& h
既然表单是用来采集用户输入的数据,那么,就应该保证用户的数据被准确地提交到预定的地点,也就是说,我们在表单提交的时候,应该对用户的数据进行检验,一来可以避免用户误输数据,二来可以避免用户输入非法的,或者说不合格的数据;检验合格以: O& r5 `* e3 Q5 u9 P, V
既然表单是用来采集用户输入的数据,那么,就应该保证用户的数据被准确地提交到预定的地点,也就是说,我们在表单提交的时候,应该对用户的数据进行检验,一来可以避免用户误输数据,二来可以避免用户输入非法的,或者说不合格的数据;检验合格以后,还要保证用户的数据提交到特定的程序。
% d; `2 y6 O- b: i$ T3 i 1.数据的检验5 E1 B7 i1 e0 a: Z: Q0 I+ J' T
数据的检验,通常有两种程序:客户端检验和服务器端检验。客户端检验,比较快,服务器端检验,相对来说比较慢,为了确保安全,通常同时采用,这样就可以避免用户刻意破坏。
! `0 S' P# C7 x. q, u 不管采用什么方式,数据检验的原理都是一样的,一旦用户输入的数据不符合规定,就报错,要求用户重新输入,客户端检验常使用Javascrip脚本,服务器端的视系统而定,本文不对数据检验的具体程序设计进行探讨,仅仅列举几个例子来说明。
2 `& ^- ]8 a% M/ J 样例:必填项,以及简单的数据类型检验
2 M P$ D7 q0 T6 K) D( ` 功能实现分析:
" j5 |! J2 |5 X8 l# L5 J* M' U7 } 本例给表单添加了onSubmit事件,通过onSubmit="return
9 e/ J& d! Y: y6 {% J& R CheckDate()"指定提交前,必须通过函数CheckDate()来检验,如果不合格,返回输入数据;
# c# t6 e5 D, X {' W 数据检验的函数如下: <script> function
" _6 f; G0 X7 ~6 Z* p6 h CheckDate(){ //取得输入的数据 userName = document.RedForm.userName.value;
6 M/ e- N; c2 a userEmail = document.RedForm.userEmail.value; //如果没有输入姓名 if4 u7 ?. `' {& M
(userName=="") { alert("请输入姓名"); document.RedForm.userName.focus();" }& E* ]% q* o- L! f5 j" j
return false; }else{ //如果没有输入Email,上海搬场公司或者Email地址错误(不含@) if
4 j. I* H; X7 f0 S& d ((userEmail=="")||(userEmail.indexOf("@")==-1)) {2 |& C/ n6 w! b9 \: f9 @8 o7 `
alert("请重新输入Email地址"); document.RedForm.userEmail.focus(); return
/ c* G: D' [ U5 z false; }else return true; } }0 e& W7 T' z; ]7 j
</script>9 i' `8 v6 G) z# U& ~5 Q* g
以下带*的必须输入:
. M$ d4 i% u0 L0 z7 {, w 姓名: *
: n2 O8 x1 V+ \8 j9 ^; B* w5 v" C, z Email: *
* F" q3 R' Q q- v* p5 V 表单的分支提交" c0 L! o' |. N3 E, v4 }$ ?; r
有的时候http://www.zyldjd.com/,大众搬家表单需要根据用户的选择,提交到不同的程序,怎么做呢?通过脚本来检测用户的选择分支,从而向不同的程序提交表单,看看样例:: z6 x. O3 y- L- q" _2 h* a
样例:分支提交
1 c$ e. F* Y$ m* O6 m7 g, t* O- q 用户名: 密码:7 F. c2 h+ S$ @3 c& Q
公司用户 个人用户0 b p" |$ `) b0 t. F3 @
功能实现分析:
; F6 l; x/ X9 N& a$ Q- k 这里首先用到的是form的onSubmit="TwoSubmit(this)"- U; u; ~, B+ S3 k6 x8 e2 D3 k' ^
然后根据选择的分支http://www.sh6997.comhttp://www.xiangpaiming.com,上海搬家公司来分别递交到不同的程序,大众搬场TwoSubmit()函数如下:( b/ u( K: @1 B3 W) F z: H1 Q
<script> function TwoSubmit(form){ if
& |$ H8 p' w8 ]5 F5 w (form.Ref[0].checked){ form.action = "cop.asp";//这里是分之一 }else{
2 B$ B9 n, q! a9 e; q2 V$ A form.action = "ind.asp";//这里是分之二 } form.submit(); }
; b D8 x% P# ]( T; h3 D3 ] </script>
# `0 T! K/ J7 q. m- V 用任何元素提交表单
C7 e6 [% V2 [! l, b& M. B 是不是只有按钮或者图片按钮才能提交表单呢?当然不是,实际上,任何页面元素都可以提交表单,不过嘛,都是通过脚本来完成的,下面我们就使用链接来代替Submit按钮:
t, x1 _7 P3 i( h P" | [恶搞]表格中单元格之间分隔线的隐藏方法_ |
|