JSONP 跨域访问代理API-yahooapis实现代码 - Web前端
作者:98wpeu发布时间:2026-06-08分类:网页前端技术浏览:64
导读:你是否遇到了想利用Ajax访问一些公网API,但是你又不想建立自己的代理服务,因为有时我根本就没打算涉及服务端任何代码,但是讨厌的浏览器的同源策略,阻止了我们的ajax调用。比如...
你是否遇到了想利用Ajax访问一些公网API,但是你又不想建立自己的代理服务,因为有时我根本就没打算涉及服务端任何代码,但是讨厌的浏览器的同源策略,阻止了我们的ajax调用。
比如我想访问一个天气的restfull api,如果我直接去get:
复制代码 代码如下:
$.get("http://m.weather.com.cn/data/101010100.html");
看见这问题相信大家都不会陌生,也会很自然的得到解决方案,但是我这里真的不想touch任何服务端代码,用JSONP吧,但是服务端没实现契约。
在这里我是时候引入主角Yahoo提供的jsonp代理:HTTP://query.yahooapis.com/v1/public/yql
实现跨域访问代码为:http://JSfiddle.net/whitewolf/4UDpf/9/
HTML:
复制代码 代码如下:
<scripttype="text/javascript" src="http://ajax.CDNjs.com/ajax/libs/JSON2/20110223/json2.js"></script>
<div id="content">
</div>
复制代码 代码如下:
js:
$(function(){
$.getJSON("http://query.yahooapis.com/v1/public/yql", {
q: "select * from json where url=\"http://m.weather.com.cn/data/101010100.html\"",
FORMat: "json"
}, function(data) {
var $content = $("#content")
if (data.query.results) {
$content.text(JSON.stringify(data.query.results));
} else {
$content.text('no such code: ' + code);
}
});
});
效果:
多的就不用说了,jsonp原理我相信大家也很清楚。
比如我想访问一个天气的restfull api,如果我直接去get:
复制代码 代码如下:
$.get("http://m.weather.com.cn/data/101010100.html");
看见这问题相信大家都不会陌生,也会很自然的得到解决方案,但是我这里真的不想touch任何服务端代码,用JSONP吧,但是服务端没实现契约。
在这里我是时候引入主角Yahoo提供的jsonp代理:HTTP://query.yahooapis.com/v1/public/yql
实现跨域访问代码为:http://JSfiddle.net/whitewolf/4UDpf/9/
HTML:
复制代码 代码如下:
<scripttype="text/javascript" src="http://ajax.CDNjs.com/ajax/libs/JSON2/20110223/json2.js"></script>
<div id="content">
</div>
复制代码 代码如下:
js:
$(function(){
$.getJSON("http://query.yahooapis.com/v1/public/yql", {
q: "select * from json where url=\"http://m.weather.com.cn/data/101010100.html\"",
FORMat: "json"
}, function(data) {
var $content = $("#content")
if (data.query.results) {
$content.text(JSON.stringify(data.query.results));
} else {
$content.text('no such code: ' + code);
}
});
});
效果:
多的就不用说了,jsonp原理我相信大家也很清楚。
相关推荐
- jquery做的一个简单的屏幕锁定提示框 - Web前端
- jquery获取复选框被选中的值 - Web前端
- 类似天猫商品详情随浏览器移动的示例代码 - Web前端
- Jquery easyUI 更新行示例 - Web前端
- 使用jQuery中的when实现多个AJAX请求对应单个回调的例子分享 - Web前端
- Jquery获取和修改img的src值的方法 - Web前端
- 基于JQuery实现的Select级联 - Web前端
- 2013年优秀jQuery插件整理小结 - Web前端
- jquery sortable的拖动方法示例详解 - Web前端
- 为开发者准备的10款最好的jQuery日历插件 - Web前端
- 网页前端技术排行
-
- 1【第六章】Foundation之按钮和下拉功能 - Web前端
- 2jQuery编写widget的一些技巧分享 - Web前端
- 3在Mac/PC上远程调试iPhone/iPad上的网页 - Web前端
- 4jQuery实例教程:制作网页中可折叠的面板 - Web前端
- 5基于jquery的滚动条滚动固定div(附演示下载) - Web前端
- 6分析Iconfont-阿里巴巴矢量常用图标库 - Web前端
- 7分享精心挑选的12款优秀jQuery Ajax分页插件和教程 - Web前端
- 8[Web前端]用javascript实现默认图片替代未显示的图片 - Web前端
- 9JS网页制作实例:标签云 - Web前端
- 最近发表
-
- WordPress随机显示特色图片插件:Random Post Thumbnails
- KeePass实现Chrome浏览器自动填充密码方法一
- LNMP一键包nginx 301强制跳转到https教程
- KeePass实现Chrome浏览器自动填充密码方法二
- #建站# 免费的VPS管理软件Xshell8/Xftp8中文版下载
- 使用Xshell 8连接VPS教程_电脑登录vps的方法
- WordPress评论界面添加烟花????效果
- 不同浏览器书签同步方案:坚果云+Floccus_详细使用教程
- iOS端KeePassXC客户端APP:Strongbox Password Safe
- 给WordPress评论中的Gravatar头像图片添加ALT属性


