帝国CMS-AJAX验证标题是否重复方法
1、帝国cms后台 - 管理数据表 - 找到自己使用的数据表 - 修改title字段 - 输入表单使用下面的代码
找到代码
<inputtype=textname=titlevalue="<?=ehtmlspecialchars(stripSlashes($r[title]))?>"size="60">
替换为
<inputtype=textname=titlevalue="<?=ehtmlspecialchars(stripSlashes($r[title]))?>"size="60"onblur="checkTitle()">
在输入表单最下面加入如下代码
接着新建一个php文件,保存在 /e/admin/ReTitleAjax.php ,代码如下
- <script type="text/javascript"src="http://apps.bdimg.com/libs/jquery/1.9.0/jquery.min.js"></script>
- <script type="text/javascript">
- functioncheckTitle()
- {
- varclassid=<?=$_GET[classid]?>;
- varid=<?=$_GET[classid]?>;
- vartit=document.add.title.value;
- console.log("我是标题="+tit);
- console.log("我是classid="+classid);
- console.log("我是id="+id);
- $.ajax({
- url: 'ReTitleAjax.php?classid='+classid+'&id='+id+'&title='+tit,
- dataType:"json",
- cache: false,
- error: function(){
- alert("检测失败,请重试");
- },
- success: function(data){
- if(data==1){
- alert('重复标题');
- }
- if(data==0){
- //alert('可以添加信息');
- console.log("可以添加信息");
- }
- }
- });
- }
- </script>
上面是采用post查询返回json结果的方式来实现查重,我们还可以通过get方式,js函数如下:
- define('EmpireCMSAdmin','1');
- require("../class/connect.php");
- require("../class/db_sql.php");
- require("../class/functions.php");
- requireLoadLang("pub/fun.php");
- require("../data/dbcache/class.php");
- $link=db_connect();
- $empire=newmysqlquery();
- $editor=1;
- //验证用户
- $lur=is_login();
- $logininid=$lur['userid'];
- $loginin=$lur['username'];
- $loginrnd=$lur['rnd'];
- $loginlevel=$lur['groupid'];
- $loginadminstyleid=$lur['adminstyleid'];
- $classid=(int)$_GET['classid'];
- $id=(int)$_GET['id'];
- $title=AddAddsData($_GET['title']);
- $where='';
- if($id)
- {
- $where=' and id<>'.$id;
- }
- //已审核
- $num=$empire->gettotal("select count(*) as total from {$dbtbpre}ecms_".$class_r[$classid][tbname]." where title='".addslashes($title)."'".$where." limit 1");
- //未审核
- if(emptyempty($num))
- {
- $num=$empire->gettotal("select count(*) as total from {$dbtbpre}ecms_".$class_r[$classid][tbname]."_check where title='".addslashes($title)."'".$where." limit 1");
- }
- echojson_encode($num);
接着在title字段的input后放一个容器用于存储提示信息,例如<span id="titletips"></span>,还可以通过在出现重复时禁用其他input输入等方式来限制,这里只是给出原理,大家可在此基础上发挥。
- <script type="text/javascript">
- functioncheckTitle()
- {
- varclassid='<?=$_GET[classid]?>';
- varid='<?=$_GET[id]?>';
- vartit=document.add.title.value;
- varanswerurl='ReTitleAjax.php';
- $.get(answerurl+"?classid="+classid+'<?=$ecms_hashur['ehref']?>&title='+tit, function(data){
- if(data){
- if(data==1){
- $("#titletips").html("<font color='red'>已经存在此名称,请检查是否已经添加过</font>");
- }
- else{
- $("#titletips").html("<font color='green'>可以添加信息</font>");
- }
- returnfalse;
- }
- else{
- $("#titletips").html("<font color='red'>检测失败,请重试</font>");
- }
- });
- }
- </script>