织梦自定义表单验证字段不能为空,不是通过前台页面js验证,绝对灵活实用。

模板文件的修改:

1、修改diy_field_add.htm,23行左右添加代码

var necessary = theform.necessary[0].checked?theform.necessary[0].value:theform.necessary[1].value;

替换字符串,大概在38行

替换revalue =  "

为revalue =  "


2、diy_field_add.htm,大概124行后面,添加代码

     

     

      是否为必填项:

      防止恶意提交表单

     

     

       

         是

           

       

         否

     

   


3、修改diy_field_edit.htm,18行左右添加代码

var necessary = theform.necessary[0].checked?theform.necessary[0].value:theform.necessary[1].value;

替换字符串,大概在38行

替换revalue += " isnull=\""+sisnull+"\" default=\""+vdefault+"\" ";

为revalue += " isnull=\""+sisnull+"\" necessary=\""+necessary+"\" default=\""+vdefault+"\" ";


4、diy_field_edit.htm,大概139行后面添加代码

 

      是否为必填项:

        防止恶意提交表单

     

        GetAtt('necessary')=='true') echo " checked='1' "; ?> class='np' />

        是   

        GetAtt('necessary')=='false'||$ctag->GetAtt('necessary')=='') echo " checked='1' "; ?> class='np' />

        否  

     


5、表单提交处理:

修改plus/diy.php文件

找到$addvar = $addvalue = '';在上面添加代码


        //验证必填字段

        $row = $dsql->GetOne("SELECT * FROM `#@__diyforms` WHERE `table`='{$diy->table}'");

        $fieldset = $row['info'];

        require_once(DEDEINC."/dedetag.class.php");

        $dtp = new DedeTagParse();

        $dtp->SetNameSpace("field","<",">");

        $dtp->LoadSource($fieldset);

        if(is_array($dtp->CTags))

        {

            foreach($dtp->CTags as $tagid=>$ctag)

            {

                if($ctag->GetAttribute("necessary")=='true' && empty(${$ctag->GetName()}))

                {

                     showmsg($ctag->GetAttribute("itemname")."不能为空!", -1);

                     exit;

                }

            }

        }

6、这样基本就搞定了,设置参数请通过后台字段编辑设置

dedecms验证自定义表单不为空_第1张图片

查看效果:

dedecms验证自定义表单不为空_第2张图片dedecms验证自定义表单不为空_第3张图片

转载:http://jingyan.baidu.com/article/380abd0a44f4151d90192c2a.html