我是靠谱客的博主 成就毛衣,最近开发中收集的这篇文章主要介绍emlog评论ajax,emlog评论ajax提交的两种方法,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

方法一:需要修改源代码

1.includelibfunction.base.php中

"function show_404_page()"函数上方添加函数:

/**

* 显示json信息

*

* @param string $msg 信息

*/

function myJson($msg) {

echo $msg;

exit;

}

2.includecontrollercomment_controller.php中

if($Comment_Model->isLogCanComment($blogId) === false) {

//emMsg('评论失败:该文章已关闭评论');

myJson(json_encode(array("status"=>"1")));

} elseif ($Comment_Model->isCommentExist($blogId, $name, $content) === true) {

//emMsg('评论失败:已存在相同内容评论');

myJson(json_encode(array("status"=>"2")));

} elseif (ROLE == ROLE_VISITOR && $Comment_Model->isCommentTooFast() === true) {

//emMsg('评论失败:您提交评论的速度太快了,请稍后再发表评论');

myJson(json_encode(array("status"=>"3")));

} elseif (empty($name)) {

//emMsg('评论失败:请填写姓名');

myJson(json_encode(array("status"=>"4")));

} elseif (strlen($name) > 20) {

//emMsg('评论失败:姓名不符合规范');

myJson(json_encode(array("status"=>"5")));

} elseif ($mail != '' && !checkMail($mail)) {

//emMsg('评论失败:邮件地址不符合规范');

myJson(json_encode(array("status"=>"6")));

} elseif (ISLOGIN == false && $Comment_Model->isNameAndMailValid($name, $mail) === false) {

//emMsg('评论失败:禁止使用管理员昵称或邮箱评论');

myJson(json_encode(array("status"=>"7")));

} elseif (!empty($url) && preg_match("/^(http|https)://[^<>'"]*$/", $url) == false) {

//emMsg('评论失败:主页地址不符合规范','javascript:history.back(-1);');

myJson(json_encode(array("status"=>"8")));

} elseif (empty($content)) {

//emMsg('评论失败:请填写评论内容');

myJson(json_encode(array("status"=>"9")));

} elseif (strlen($content) > 8000) {

//emMsg('评论失败:内容不符合规范');

myJson(json_encode(array("status"=>"10")));

} elseif (ROLE == ROLE_VISITOR && Option::get('comment_needchinese') == 'y' && !preg_match('/[x{4e00}-x{9fa5}]/iu', $content)) {

//emMsg('评论失败:评论内容需包含中文');

myJson(json_encode(array("status"=>"11")));

} elseif (ISLOGIN == false && Option::get('comment_code') == 'y' && session_start() && $imgcode != $_SESSION['code']) {

//emMsg('评论失败:验证码错误');

myJson(json_encode(array("status"=>"12")));

} else {

$_SESSION['code'] = null;

$Comment_Model->addComment($name, $content, $mail, $url, $imgcode, $blogId, $pid);

}

3.includemodelcomment_model.php中

2b36e768e7434834a7bd000791b94afb.png

emDirect(Url::log($blogId).'#'.$cid);替换为:

myJson(json_encode(array("status"=>"13","url"=>Url::log($blogId))));

emMsg('评论发表成功,请等待管理员审核', Url::log($blogId));替换为:

myJson(json_encode(array("status"=>"14","url"=>Url::log($blogId))));

4.前端代码核心部分示例

var data={

comname: $("#comname").val(),

comment: $("#comment").val(),

commail: $("#commail").val(),

comurl: $("#comurl").val(),

imgcode: $("input[name=imgcode]").val(),

gid: $("#comment-gid").val(),

pid: $("#comment-pid").val()

};

$.ajax({

url: 'index.php?action=addcom',

type: 'post',

dataType: 'json',

data: data,

success: function(data){

var tip = $("#commentTips");

switch(data.status){

case "1":

tip.text("主人已关闭此篇文章的评论功能啦!");

break;

case "2":

tip.text("已存在相同内容评论啦!");

break;

case "3":

tip.text("您提交评论的速度太快了,请稍后再发表评论吧!");

break;

case "4":

tip.text("请填写昵称哦!");

break;

case "5":

tip.text("昵称不超过6个汉字或者20个字符哦!");

break;

case "6":

tip.text("请填写正确的邮件地址哦!");

break;

case "7":

tip.text("不能使用管理员昵称或邮箱评论哦!");

break;

case "8":

tip.text("主页地址不符合规范哦!");

break;

case "9":

tip.text("请填写评论内容哦!");

break;

case "10":

tip.text("评论内容超出最大字数限制了哦!");

break;

case "11":

tip.text("评论内容需包含中文哦!");

break;

case "12":

tip.text("验证码不对哒!");

break;

case "13":

alert("评论发表成功!");

location.reload();

break;

case "14":

alert("评论发表成功,请等待管理员审核吧!");

location.reload();

break;

}

}

});

5.代码托管于GitHub,地址:CommentAjax

方法二:使用正则式(效果见本站评论系统)

直接上关键的js代码如下:

$("#comment_submit").click(function(event){

event.preventDefault();

doSubmitComment();

});

function doSubmitComment(){

var comname = $.trim( $("#commentform input[name=comname]").val() ),

commail = $.trim( $("#commentform input[name=commail]").val() ),

comurl = $.trim( $("#commentform input[name=comurl]").val() ),

comment = $.trim( $("#commentform textarea[name=comment]").val() ),

imgcode = $.trim( $("#commentform input[name=imgcode]").val() ),

tip = $("#commentTips"),

btn = $("#comment_submit");

if(($("#commentform input[name=comname]").length>0) && !comname){

tip.html("请填写您的昵称!");

}else if(($("#commentform input[name=commail]").length>0) && !commail){

tip.html("请填写您的邮箱!");

}else if(($("#commentform input[name=commail]").length>0) && !( /^w+([-+.']w+)*@w+([-.]w+)*.w+([-.]w+)*$/.test(commail) ) ){

tip.html("请填写正确的邮箱!");

}else if(!comment){

tip.html("请填写评论内容!");

}else if(($("#commentform input[name=imgcode]").length>0) && !imgcode){

tip.html("请填写验证码!");

}else{

$.ajax({

url: $("#commentform").attr('action'),

type: 'post',

data: $("#commentform").serialize(),

cache: false,

async:false,

beforeSend: function(){

tip.html("提交中...");

btn.attr("disabled",true);

},

success: function(res){

btn.attr("disabled",false);

var pattern = /

[rn]+

(.*?)/;

if(pattern.test(res)) {

res = res.match(pattern);

tip.html(res[1]);

}else{

window.location.href = window.location.href.split("#")[0];

}

},error: function(){

btn.attr("disabled",false);

}

});

};

};

小牛云是参考第二种办法进行的ajax评论提交修改的,其中也遇到很多问题,下面罗列一下

1、myJson函数返回的是json格式的代码,但是ajax还是识别不了

答:因为json需要header头设置为json编码,所以myJson函数还需要加一个

header('Content-type: application/json');

才能被ajax识别

2、按钮提交form表单会跳转的问题

答:这个我也是脑子烧了,最后只需要把按钮换成

3、关于安装反评论等插件,返回格式不同

答:这类插件使用的也是emMsg函数返回提示信息,所以只需要换成myJson函数即可。

4、关于重复提交问题

答:因为原版js没有加同步操作,所以只需要在ajax操作中加入async:false同步操作即可,本文已加。

上面就是小牛云在替换ajax评论提交时遇到的一些复杂问题。

最后

以上就是成就毛衣为你收集整理的emlog评论ajax,emlog评论ajax提交的两种方法的全部内容,希望文章能够帮你解决emlog评论ajax,emlog评论ajax提交的两种方法所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(81)

评论列表共有 0 条评论

立即
投稿
返回
顶部