一、JSONP简介

  JSONP 全称 JSON with padding(填充式 JSON 或参数式 JSON),JSONP实现跨域请求的原理,就是动态创建<script>标签,然后利用<script>的”src"属性不受同源策略限制来跨域获取数据,其实凡是拥有”src”属性的标签都有跨域的能力,如<script> <img> <iframe>等。JSONP 由两部分组成:回调函数和数据。回调函数是当响应到来时应该在页面中调用的函数。回调函数的名字一般是在请求中指定的。而数据就是传入回调函数中的 JSON 数据。

二、JSONP应用小案例

  下面通过在本地输入关键字,实现百度下拉小提示的功能。

1、当在百度输入关键字PHP时,有如下效果

2、右击控制台Name中选定的地址复制如下

地址为   https://sp0.baidu.com/5a1Fazu8AA54nxGko9WTAnF6hhy/su?wd=P&json=1&p=3&sid=26523_1450_21107&req=2&csor=1&cb=jQuery110208650365665803772_1540543418194&_=1540543418198

其中wd=P 中的P即为输入的关键字,cb=jQuery110208650365665803772_1540543418194 中jQuery110208650365665803772_1540543418194即为回调函数名。

2、在新标签中打开访问如下

格式为  函数名(JSON形式的参数)。

3、修改回调函数名并处理相应的JSON数据

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>JSONP实现百度下拉提示</title>
</head>
<body>
<h1>百度下拉提示</h1>
<!-- 创建输入框 -->
<input type="text">
<!-- 创建空的ul标签用于存放li -->
<ul style="display: none"></ul>
<script type="text/javascript">
// 获取输入的关键字
var oInp = document.getElementsByTagName('input')[0];
// 获取空的ul
var oUl = document.getElementsByTagName('ul')[0];
// 自定义函数search用于回调,参数data即为JSON格式数据
function search(data) {
// 打印data控制台查看组织形式
console.log(data);
}
// 给input标签绑定oninput事件
oInp.oninput = function() {
// 如果输入不为空就创建script标签
if (this.value != '') {
// 创建script标签
var oScript = document.createElement('script');
// 将关键字wd的值改为输入的值this.value,回调函数名cb的值换为本地search函数
var url = 'https://sp0.baidu.com/5a1Fazu8AA54nxGko9WTAnF6hhy/su?wd=' + this.value +'&json=1&p=3&sid=26523_1450_21107&req=2&csor=1&cb=search&_=1540543418198';
oScript.src = url;
// 将script标签追加到body
document.body.appendChild(oScript);
} else {
// 如果输入为空就隐藏ul
oUl.style.display = 'none';
}
}
</script>
</body>
</html>

输入关键字P,通过控制台查看data数组形式如下

因此要获取返回值,可通过 data.s返回一维数组,修改代码如下:

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>JSONP实现百度下拉提示</title>
</head>
<body>
<h1>百度下拉提示</h1>
<!-- 创建输入框 -->
<input type="text">
<!-- 创建空的ul标签用于存放li -->
<ul style="display: none"></ul>
<script type="text/javascript">
// 获取输入的关键字
var oInp = document.getElementsByTagName('input')[0];
// 获取空的ul
var oUl = document.getElementsByTagName('ul')[0];
// 自定义函数search用于回调,参数data即为JSON格式数据
function search(data) {
// 获取数据长度
var len = data.s.length;
if (len) {
// 如果返回数据不为空就显示ul标签
oUl.style.display = 'block';
// html用于存放ul的值
var html = '';
for (var i=0; i < len; i++) {
html += '<li>' + data.s[i] + '</li>';
}
oUl.innerHTML = html;
} else {
// 如果无返回数据就隐藏ul
oUl.style.display = 'none';
}
}
// 给input标签绑定oninput事件
oInp.oninput = function() {
// 如果输入不为空就创建script标签
if (this.value != '') {
// 创建script标签
var oScript = document.createElement('script');
// 将关键字wd的值改为输入的值this.value,回调函数名cb的值换为本地search函数
var url = 'https://sp0.baidu.com/5a1Fazu8AA54nxGko9WTAnF6hhy/su?wd=' + this.value +'&json=1&p=3&sid=26523_1450_21107&req=2&csor=1&cb=search&_=1540543418198';
oScript.src = url;
// 将script标签追加到body
document.body.appendChild(oScript);
} else {
// 如果输入为空就隐藏ul
oUl.style.display = 'none';
}
}
</script>
</body>
</html>

演示效果如下:

三、JSONP小结

通过以上小示例可知:JSONP跨域获取数据的方式,主要是通过动态生成script标签然后设置src属性,再调用本地函数来实现。严格来讲,JSONP并不是AJAX技术,因为自始至终根本没有使用XMLHTTPRequest对象,只是和AJAX一样,实现了在不刷新页面的情况下获取服务端数据的功能。

JSONP跨域访问百度实现搜索提示小案例的更多相关文章

  1. Jsonp跨域访问

    很早之前看过好几篇跨域访问的文章,然后做项目的时候基本没有遇到跨域访问的问题.不过该来的还是会来,前些天终于让我遇到了.于是重温了一下原理这些,再进行实战.于是现在也敢通过实战后的一些理解来和大家分享 ...

  2. 在ASP.NET MVC3 中利用Jsonp跨域访问

    在ASP.NET MVC3 中利用Jsonp跨域访问 在信息系统开发的时,根据相关业务逻辑难免会多系统之间互相登录.一般情况下我们需要在多系统之间使用多个用户名和密码.这样客户就需要在多个系统之间重复 ...

  3. jquery ajax怎么使用jsonp跨域访问

    在项目中使用接口的比较多,在客户端跨域访问,jquery中只能使用jquery ajax的jsonp方法. 值得注意的是,jQuery.ajax()只支持get方式的跨域,post的方式是不支持的.& ...

  4. 从前端和后端两个角度分析jsonp跨域访问(完整实例)

    一.什么是跨域访问 举个栗子:在A网站中,我们希望使用Ajax来获得B网站中的特定内容.如果A网站与B网站不在同一个域中,那么就出现了跨域访问问题.你可以理解为两个域名之间不能跨过域名来发送请求或者请 ...

  5. AJax与Jsonp跨域访问

    一.JavaScript的AJax AJAX即"Asynchronous Javascript And XML"(异步JavaScript和XML) 设计AJax使用的一种重要技术 ...

  6. JSON跨域读取那点事(JSONP跨域访问)

    最近在码一个小项目,需要远程读取json.因为需求很少,如果引用jquery使用其getjson方法就显得很浪费嘛= = 这篇文章很详细的解释了JSON跨域读取的前世今生,把原理讲得很透彻.特此分享. ...

  7. Jsonp跨域访问原理和实例

    >>什么是跨域 出于安全方面的考虑,页面中的JavaScript无法访问其他服务器上的数据,当前域名的js只能读取同域下的窗口属性,即同源策略.而跨域就是通过某些手段来绕过同源策略限制,实 ...

  8. 【AngularJs】---JSONP跨域访问数据传输

    大家会自然想到只有一个字母之差的JSON吧~ JSON(JavaScript Object Notation)和JSONP(JSON with Padding)虽然只有一个字母的差别,但其实他们根本不 ...

  9. [转载]介绍一个JSONP 跨域访问代理API-yahooapis

    你是否遇到了想利用AJAX访问一些公网API,但是你又不想建立自己的代理服务,因为有时我根本就没打算涉及服务端任何代码,但是讨厌的浏览器的同源策略,阻止了我们的ajax调用. 比如我想访问一个天气的r ...

随机推荐

  1. php CI框架

    CodeIgniter 是一个小巧但功能强大的 PHP 框架,作为一个简单而“优雅”的工具包,它可以为 PHP 程序员建立功能完善的 Web 应用程序.如果你是一个使用共享主机,并且为客户所要求的期限 ...

  2. docker修改docker0 mtu

    由于docker宿主机设置了mtu造成docker镜像中mtu和宿主机mtu不匹配,大包后网络不同.所以需要设置docker0的mtu. 1.修改docker.service vi /usr/lib/ ...

  3. Aspose.Words 自定义文档模版生成操作类

    /// <summary> /// 操作word通用类 LIYOUMING add 2017-12-27 /// </summary> public class DocHelp ...

  4. glBlendFunc的几种常用情况

    先Mark一下,后面有时间补上DEMO 1.画航母大灯,手电筒(效果为:透过黑色半透明层可看到下面的背景图,仅圆圈部分) 1)先画圆圈 2)再画背景图(大背景) 大背景设置  glBlendFunc ...

  5. 安装配置SVN

    官网下载地址,下载完之后如果想看到中文,可以下载语言包进行安装,安装之后TortoiseSVN -> Settings -> General -> Language选项中选择:中文( ...

  6. day7 面向对象class()学习

        面向过程 VS 面向对象     编程范式 编程是程序员用特定的语法+数据结构+算法组成的代码来告诉计算机如何执行任务的过程,一个程序是程序员为了得到一个任务结果而编写的一组指令的集合,正所谓 ...

  7. zoj 3983 Crusaders Quest 思维+枚举

    题目链接 这道题意思是: 给你一个长度为9的字符串,且只有3个a.3个g.3个o 问,你可以选择删除一段连续的串或者单个的字符也可以不删,最多会出现几个三子相连的子串 比如:agoagoago只有将两 ...

  8. <泛> 多路快排

    今天写一个多路快排函数模板,与STL容器兼容的. 我们默认为升序排序 因为,STL容器均为逾尾容器,所以我们这里采用的参数也是逾尾的参数 一.二路快排 基本思路 给你一个序列,先选择一个数作为基数,我 ...

  9. Stream中reduce()使用记录

    一.reduce()使用1.第一个参数是我们给出的初值,2.第二个参数是累加器,可以自己用实现接口完成想要的操作,这里使用Bigdecimal的add方法 3.最后reduce会返回计算后的结果 Bi ...

  10. 在Tomcat中部署web项目的三种方式

    搬瓦工搭建SS教程 SSR免费节点:http://www.xiaokeli.me 在这里介绍在Tomcat中部署web项目的三种方式: 1.部署解包的webapp目录 2.打包的war文件 3.Man ...