java ajax 点赞功能_Ajax+jQuery+bootstrap+Java实现异步点赞功能,并限制点击次数

在很多的网站上有很多不同的点赞,我不知道他们是怎么实现的,下面我来分享一下我写的点赞实现,共大家参考下,

这是我在一个项目抽取的代码,可能有些样式会发生变化,但是功能不会影响。

网页代码:

这个是根据数据库中是否可以点赞来限制能不能点的,strlist是从java后台返回的一个请求。在这里取出点赞数和文章点赞的编号做为参数到Ajax上

class="btn btn-default btn-xs">

${strlist.dzCount}

${strlist.dzCount}

Ajax请求的Js脚本:

function praise(recordNo, praiseCount) {

$.ajax({

url: '${ctx}/country/pointPraise',

type: 'POST',

data: {

'recordNo': recordNo

},

dataType: "JSON",

success: function(d) {

if (d.success) {

var strategyPraiseNo = parseInt(praiseCount) + 1;

$('#praiseNo' + recordNo).html(strategyPraiseNo)

}

},

error: function(XMLHttpRequest, textStatus, errorThrown) {

bootbox.alert("无法连接服务器:" + textStatus);

}

});

}

Java代码:

Dao类接口层

/**

* @Title: updateDzCount

* @Description:点击赞后更改赞的数量

* @param mapNo

* @author CHENJH

* @date 2015年6月27日

*/

public void updateDzCount(HashMap mapNo);

Dao类实现层

@Override

public void updateDzCount(HashMap mapNo) {

this.update("updateDzCount", mapNo);

}

service类接口层/**

* @Title: updateDzCount

* @Description:点击赞后更改赞的数量

* @param recordNo

* @author CHENJH

* @date 2015年6月25日

*/

public boolean updateDzCount(HashMap mapNo);

service类实现层

@Override

public boolean updateDzCount(HashMap mapNo) {

logger.info("***** BlogServiceImpl.updateDzCount() method begin*****");

boolean flag = true;

try {

blogDao.updateDzCount(mapNo);

} catch (Exception e) {

logger.error("------updateDzCount error:", e);

e.printStackTrace();

return false;

}

logger.info("***** BlogServiceImpl.updateDzCount() method end*****");

return flag;

}

Action类处理层代码

/**

* @Title: pointPraise

* @Description: 修改文章点赞

* @author CHENJH

* @date 2015年6月27日

*/

@SkipCheck

@Action("pointPraise")

public void pointPraise() {

String recordNo = getParam("recordNo");// 获取文章信息编号

HashMap mapNo = getSessionValue("recordNoMap");// 得到文章点赞集合

Boolean bool = false;

if (mapNo != null) {

if (mapNo.get(recordNo) == null) {// 判断集合中是否存在改编号点赞

mapNo.put(recordNo, recordNo);

bool = true;

}

} else {// 未进行点赞

mapNo = new HashMap();

mapNo.put(recordNo, recordNo);

setSessionAttr("recordNoMap", mapNo);

bool = true;

}

if (bool) {// 可以点赞

mapNo.put("recordNo", recordNo);

// 点赞更新值

bool = blogService.updateDzCount(mapNo);

}

outputJsons("success", bool);

}

MyBatis3映射文件SQL语句

update TAB_攻略表 set

点赞次数=((select 点赞次数 from TAB_攻略表 where 记录编号 = #{recordNo,jdbcType=VARCHAR})+1)

where 记录编号 = #{recordNo,jdbcType=VARCHAR}

注:项目采用Maven开发,

this.update("updateDzCount", mapNo);

上采用了封装的。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值