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. Git关于Tag操作

    Git关于tag的操作 记录下git关于 tag的操作 列出所有标签 git tag : 列出所有的 git tag -l 'v1.2.4.*' : 最后一位任意匹配 新建标签 git tag -a ...

  2. hadoop集群启动时DataNode节点启动失败

    错误日志如下: ************************************************************/ 2018-03-07 18:57:35,121 INFO o ...

  3. 洪水 Pow

    Description AKD市处在一个四面环山的谷地里.最近一场大暴雨引发了洪水,AKD市全被水淹没了.Blue Mary,AKD市的市长,召集了他的所有顾问(包括你)参加一个紧急会议.经过细致的商 ...

  4. .net程序员业余Android开发赚点外快(介绍一下自己的经验)

    记得是11年10月份开始研究android的,当时还不会java,听说android比较火,自己也买了个垃圾android机,平时工作也不是特别忙,于是我就突发奇想,想试试做一下android应用可不 ...

  5. SpringBoot 2.0中SpringWebContext 找不到无法使用的问题解决

    为了应对在SpringBoot中的高并发及优化访问速度,我们一般会把页面上的数据查询出来,然后放到redis中进行缓存.减少数据库的压力. 在SpringBoot中一般使用 thymeleafView ...

  6. js push(),pop(),shift(),unshift()

    以前没有太在意这些,这几天看<Javascript 设计模式与开发实践>(不得不说这是一本好书) 发现总是会用到这几个函数,可是有什么区别呢?? 简单来说是两套东西(数据结构时老师详细的讲 ...

  7. 字符串在forEach方法里面可以使用include函数

    今天在写项目的时候,发现了一个问题,使用forEach函数,arr数组里面的字符串可以调用include方法,我查阅了很多地方,string里面没有这个方法. 但是在forEach函数里面确实可以这样 ...

  8. PC端和手机端页面的一丢丢区别

    <!DOCTYPE html> <html lang="en"> <head>     <meta charset="UTF-8 ...

  9. 【复习笔记】CSS基础

    外观 color:rgba(255,255,255,1),a表示alpha,透明度值0~1 font-family:字体1,字体2,字体3;确保某字体不存在时自动选择下一个,最好使用字体的英文名称保证 ...

  10. u-boot剖析(一)----Makefile分析

    由于u-boot比较庞大,所以我们分开来分析,对于一个大型的项目我们想快速的了解其代码架构和内容,最方便的方法就是分析Makefile,所以我们今天以三星的s3c2440来分析Makefile.我们今 ...