JQuery之Ajax

最近学了Ajax,Ajax可以在不刷新页面的情况和服务器通信,Jquery也有Ajax,下面记录下原生JS的Ajax和JQuery的Ajax

这里使用了百度的热搜接口,https://www.baidu.com/su?wd=?&cb=?

JS原生Ajax

function getData(data){
				var script = document.querySelector('#jsonp');
				script.parentNode.removeChild(script);
				$('ul').html('');
				for(var i = 0 ;i<data.s.length;i++){
					$('<li>'+ data.s[i] +'</li>').appendTo('ul');
					console.log("ss");
				}
			}
			function getList(wd){
				var script = document.createElement('script');
				script.id = 'jsonp';
				console.log(wd);
				script.src = 'https://www.baidu.com/su?cb=getData&wd=' + wd;
				document.body.appendChild(script);
			}
			$('input').keyup(function(){
				var wd = $(this).val();
				getList(wd);
			})

这样通过百度热搜接口查找input的value的热搜;wd=后面跟的就是想要搜索的关键字

在JQuery下Ajax简单多了

            var v = $('input').val();
			$.ajax({
				type:'get',
				url:'https://www.baidu.com/su',
				dataType:'jsonp',
				jsonp:'cb',
				data:{
					wd:v
				}
			}).done(function(resp){
				alert(resp.s);
			})

当时,我input的value是sss,但将wd=sss传过去,返回的内容中s是空的ade18e780dd814751ed3e3531cd3145c96c.jpg

我以为没获取到input的value,然后在控制台输出value,确有其值,那就奇怪了,为什么没搜到呢,我一度以为Jquery的ajax下data不能传变量,所以才没把value传到服务器去,结果。。。。。。input的value改成其他的,就能得到返回的s内容。由此得出sss这个字符串估计没人搜。。。。。。。。

转载于:https://my.oschina.net/u/4069817/blog/3031665

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值