sell 模块的form表单如下:

<form method="post" id="dform" action="?" target="send" onsubmit="return check();">

<tr>

<td class="tl"><span class="f_red">*</span> 行业分类</td>

<td class="tr"><div id="catesch"></div>

{ajax_category_select('post[catid]', '选择分类', $catid, $moduleid, $DT_TOUCH ? '' : 'size="2" style="height:120px;width:180px;"')}{if !$DT_TOUCH}<br/>

{/if}{if $DT[schcate_limit]}{/if}<span id="dcatid" class="f_red"></span></td>

</tr>

表单验证函数 check()

{if $action == 'add' || $action == 'edit'}

<script type="text/javascript">

function _p() {

if(Dd('tag').value) {

Ds('reccate');

}

}

function check() {

var l;

var f;

f = 'catid_1';     //存储分类id的隐藏表单

if(Dd(f).value == 0) {

Dmsg('请选择所属分类', 'catid', 1);   //Dmsg 函数在/file/script/common.js  函数详细介绍传送门

return false;

}

f = 'title';

l = Dd(f).value.length;

if(l < 2 || l > 30) {

Dmsg('信息标题应为2-30字,当前已输入'+l+'字', f);    //在dtitle标签显示提示 并且不滚动到dtitle标签,

//如果想要滚动到 用Dmsg('信息标题应为2-30字,当前已输入'+l+'字', f,1);

return false;

}

{if $MOD[upload_thumb] && $MG[upload]}

f = 'thumb';

l = Dd(f).value.length;

if(l < 5) {

Dmsg('请上传第一张产品图片', f);

return false;

}

{/if}

{if !$_userid}

f = 'company';

l = Dd(f).value.length;

if(l < 2) {

Dmsg('请填写公司名称', f);

return false;

}

if(Dd('areaid_1').value == 0) {

Dmsg('请选择所在地区', 'areaid');

return false;

}

f = 'truename';

l = Dd(f).value.length;

if(l < 2) {

Dmsg('请填写联系人', f);

return false;

}

f = 'mobile';

l = Dd(f).value.length;

if(l < 7) {

Dmsg('请填写手机', f);

return false;

}

{/if}

{if $FD}{fields_js()}{/if}

{if $CP}{property_js()}{/if}

{if $need_password}

f = 'password';

l = Dd(f).value.length;

if(l < 6) {

Dmsg('请填写支付密码', f);

return false;

}

{/if}

{if $need_question}

f = 'answer';

l = Dd(f).value.length;

if(l < 1) {

Dmsg('请填写验证问题', f);

return false;

}

if(Dd('c'+f).innerHTML.indexOf('error') != -1) {

Dd(f).focus();

return false;

}

{/if}

{if $need_captcha}

f = 'captcha';

l = Dd(f).value;

if(!is_captcha(l)) {

Dmsg('请填写正确的验证码', f);

return false;

}

if(Dd('c'+f).innerHTML.indexOf('error') != -1) {

Dd(f).focus();

return false;

}

{/if}

return true;

}

var destoon_oauth = '{$EXT[oauth]}';

</script>

{/if}

Dmsg 函数详情

//Dmsg 函数在/file/script/common.js

//str-提示信息

//i-需要验证表单id ,例如 catid,title

//s-滚动到提示表单位置的开关 1-滚动,0-不滚动,提示信息是显示到id名为“d”+i的标签里的,所以页面上必须有个 dcatid 和 dtitle才行

//t-显示提示信息的时间,显示一会后会自动隐藏

function Dmsg(str, i, s, t) {

var t = t ? t : 5000; //t的默认值是5000,如果没有传t参数则默认5000毫秒。

var s = s ? 1 : 0;    //s的默认值是0

var h = i == 'content' ? 450 : 50;  //表单高度

try{

if(typeof Dbrowser != 'undefined') {alert(str);return;}

if(s || i == 'content'){$("html, body").animate({scrollTop:$('#d'+i).offset().top-h}, 100);}

Dd('d'+i).innerHTML = '<img src="'+SKPath+'image/check_error.gif" width="12" height="12" align="absmiddle"/> '+str+sound('tip');

Dd(i).focus();

}catch(e){}

window.setTimeout(function(){Dd('d'+i).innerHTML = '';}, t);

}

destoon 升级了 dmsg函数  但是这个函数也不好用

function Dmsg(str, i, s, t) {

var t = t ? t : 5000; var s = s ? true : false;

try{if(s){window.scrollTo(0,0);}Dd('d'+i).innerHTML = '<img src="'+SKPath+'image/check_error.gif" width="12" height="12" align="absmiddle"/> '+str+sound('tip');Dd(i).focus();}catch(e){}

window.setTimeout(function(){Dd('d'+i).innerHTML = '';}, t);

}

destoon 信息发布表单提交验证的更多相关文章

  1. amazeUI表单提交验证--input框required

    效果: html: <!DOCTYPE html> <html> <head> <meta charset="utf-8"> < ...

  2. aspx中的表单验证 jquery.validate.js 的使用 以及 jquery.validate相关扩展验证(Jquery表单提交验证插件)

    这一期我们先讲在aspx中使用 jquery.validate插件进行表单的验证, 关于MVC中使用 validate我们在下一期中再讲     上面是效果,下面来说使用步骤 jQuery.Valid ...

  3. Angualr6表单提交验证并跳转

    在Angular6中,使用NG-ZRROR作为前端开发框架,在进行表单开发时遇到了一些问题,最后解决了,在此记录. 1.表单构造: 引入forms: import { FormGroup, FormB ...

  4. 原生JS 表单提交验证器

    转载:http://www.cnblogs.com/sicd/p/4613628.html 一.前言 最近在开发一个新项目,需要做登陆等一系列的表单提交页面.在经过“缜密”的讨论后,我们决定 不用外部 ...

  5. CodeIgniter典型的表单提交验证代码

    view内容: <?php echo form_open('user/reg'); ?> <h5>用户名</h5> <input type="tex ...

  6. easyui表单提交验证form

    方式一,不需要考虑jquery.easyui.min.js版本 <script> $(function () { //针对 设置 novalidate:true $('.validateb ...

  7. js 日期格式、内容合法、比较大小、表单提交验证

    1 <!DOCTYPE html> 2 <html> 3 <head> 4 <meta charset="utf-8"/> 5 &l ...

  8. PHP表单提交验证各种方式

    <!DOCTYPE unspecified PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www. ...

  9. ng 表单提交验证

    http://www.runoob.com/try/try.php?filename=try_ng_validate

随机推荐

  1. A.dreamstart的催促

    题目描述 有一天集训队的学弟们正在计算一堆数,但是dreamstart感觉他们算的太慢了,就让他们坐在一起想出一个快速计算的方法,但是由于他们一时想不出来,想让你帮助他们.他们说现在有一个数列,要算出 ...

  2. AtCoder Beginner Contest 071 ABCD

    1001 求个绝对值比较大小喽 1002 把字符串出现的字母记录一下,然后遍历a-z,谁第一个没出现就输出谁 1003 Problem Statement We have N sticks with ...

  3. namedJDBC查询

    import java.util.ArrayList; import java.util.List; import org.apache.log4j.Logger; import org.spring ...

  4. 运行node提示:events.js:160 throw er; // Unhandled 'error' event

    运行node时遇到下述提示: events.js:160  throw er; // Unhandled 'error' event或者events.js:160       throw er; // ...

  5. IO扩展芯片

    PCF8574:一个I2C接口+INT中断引脚口扩展出一个可输出输出的并口P0~P7,INT可以用于中断响应

  6. Spark Mllib里如何建立密集向量和稀疏向量(图文详解)

    不多说,直接上干货! 具体,见 Spark Mllib机器学习实战的第4章 Mllib基本数据类型和Mllib数理统计

  7. MapReduce作业的执行流程

    MapReduce任务执行总流程 一个MapReduce作业的执行流程是:代码编写 -> 作业配置 -> 作业提交 -> Map任务的分配和执行 -> 处理中间结果 -> ...

  8. [转]使用 HTML5 WebSocket 构建实时 Web 应用

    HTML5 WebSocket 简介和实战演练 本文主要介绍了 HTML5 WebSocket 的原理以及它给实时 Web 开发带来的革命性的创新,并通过一个 WebSocket 服务器和客户端的案例 ...

  9. linux debian 时间设置中无法选择“自动设定时间和日期”

    没有安装ntpdate 执行:apt-get install ntpdate ntp.sjtu.edu.cn 202.120.2.101 (上海交通大学网络中心NTP服务器地址)s1a.time.ed ...

  10. mongodb关联查询 和spring data mongodb

    GITHUB:https://github.com/peterowang/Springdata-mongo 使用DBRefs DBRefs中有三个字段 - $ref - 此字段指定引用文档的集合 $i ...