JQ自动调用、Ajax跨域调用

问题描述

      在央视官网划水的时候,发现一个点赞排名,试着点击了几次,竟然发现没有防重复提交,如下图:

在这里插入图片描述
于是想着用代码实现自动间隔点赞

初步代码实现

      初始代码如下:

$(function() {
				var num = 0;
				setInterval(function() {
					$.ajax({
						type: "get", //请求方式
						url: "http://*********TACT1499325086744310&num=1&jsonp_callback=TACT1499325086744310",
						success: function(data) {
							//请求成功处理,和本地回调完全一样
							console.log("点赞成功" + num + "次");
							num++;
						},
						error: function() {
							//请求出错处理
							console.log(data);
						}
					});
				}, 1000);
			});
代码解释
$(function() {
		setInterval(function() {
                  //dosomething
                 },num)
		}
)

setInterval() :是一个定时器,里面的 function是一个匿名函数 ,我们可以把想执行的一些代码写在里面;
num :这是一个参数,表示多少毫秒执行一直,我这里写1000就表示每秒钟执行一次.

ajax跨域问题

但是这样请求的话,会出现如下的 ajax跨域调用问题:
在这里插入图片描述

查询了一些资料以后,得出以下最终的解决办法如下:

$(function() {
		var num = 0;
		setInterval(function() {
			$.ajax({
				type: "get", //请求方式
				async: true, //是否异步
				url: "http://***************TACT1499325086744310&num=1&jsonp_callback=TACT1499325086744310",
				dataType: "jsonp", //跨域json请求一定是jsonp
				jsonp: "jsonp_callback", //跨域请求的参数名,默认是callback
				//jsonpCallback:"successCallback",    //自定义跨域参数值,回调函数名也是一样,默认为jQuery自动生成的字符串
				data: {
					"query": "civilnews"
				}, //请求参数
				beforeSend: function() {
					//请求前的处理
				},
				success: function(data) {
					//请求成功处理,和本地回调完全一样
					console.log("点赞成功" + num + "次");
					num++;
				},
				complete: function() {
					//请求完成的处理
				},
				error: function() {
					//请求出错处理
					console.log(data);
				}
			});
		}, 1000);
	});
最终效果

在这里插入图片描述

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值