form的onsubmit事件--表单提交前的验证最佳实现方式

 

遇到了一个问题,页面中include了很多的公共页面(都是没有form的),并且里面好多的地方都是自行提交的(页面中加入一个type=“submit”域,然后js中写入sumbit.click来执行提交的)。但我需要在每次提交前都要验证一下表单中的填写是否符合要求,如果我给每个提交的地方都添加验证函数的调用,那工作量就大了。

    这时我得需要一个措施,就是在表单提交前统一进行验证。从body有页面关闭前的事件onbeforeunload推想到,form应该也有提交前的事件,上网一查,真有,就是onsubmit。此事件的功能就是在表单提交前自动执行指定的东西。

    需要注意的是,οnsubmit=“return check()”中的return是一定要加上的,不然check的返回值哪怕是false,仍然提交。也就是说,οnsubmit=“return false”为不执行提交;οnsubmit=“return true”或οnsubmit=“return ”都执行提交;

------------------------------------------

主页面如下:

<HTML>

<HEAD>

<script type="text/javascript">

//form提交前,验证:营销活动最少选择两个
function check(){
    if(验证条件不通过){
        return false;
    }else{

        return true;//不写此返回值也行,此时就直接提交了

    }
}
</script>

</HEAD>
<body οnlοad="doOnLoad()">
<form id="queryForm" οnsubmit="return check()" action="<%=request.getContextPath()%>/FocReportServlet">

<jsp:include flush="true" page="../pub.jsp"/>
<jsp:include flush="true" page="../condition.jsp"/>
<jsp:include flush="true" page="condition_marketing.jsp"/>
<jsp:include flush="true" page="contrastChart.jsp"/>

<jsp:include flush="true" page="../pagectrl.jsp"/>

...

<input type="submit" id="submit" name="submit" style="visibility:hidden"/>

 

<HTML>

-----------------------------------

include页面中提交方式:

<img src="<%=request.getContextPath()%>/focReport/images/control_play_blue.png" style="cursor:hand" οnclick="sending.style.visibility='visible';submit.click()" alt="点击提交分析">

 

 

DWZ 中界面提示

 

alertMsg.confirm("确认删除场地及所有相关信息(场位、业主、租户、科目、收费)。此操作不可逆转", {
    okCall : function() {
     ajaxTodo('${ctx}/lpcd/delete/${lpCd.id}', navTabAjaxDone);
    }
   });

 

 alertMsg.warn("请选择场地!");

 

 

function checkInfo(){ //判断多个复选框中是否选中
  $("input[name='org3.otherValues']").each(
   function(){
   if($(this).get(0).checked){
   return true;
    }
   });
  var org3_ids=$("#org3_ids").val();
  if(org3_ids!=''){
   return true;
  }
  
  alertMsg.warn("请选择接收人!");
  return false;
 }

 

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值