JSONP 跨域访问代理API-yahooapis实现代码 - Web前端
作者:98wpeu发布时间:2026-06-08分类:网页前端技术浏览:6
导读:你是否遇到了想利用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实现漂浮在网页右侧的qq在线客服插件示例 - Web前端
- Jquery实现鼠标移上弹出提示框、移出消失思路及代码 - Web前端
- jquery实现的一个导航滚动效果具体代码 - Web前端
- jQuery数据缓存功能的实现思路及简单模拟 - Web前端
- jQuery解决下拉框select设宽度时IE 6/7/8下option超出显示不全 - Web前端
- jQuery 过滤方法filter()选择具有特殊属性的元素 - Web前端
- jQuery根据纬度经度查看地图处理程序 - Web前端
- jQuery输入城市查看地图使用介绍 - Web前端
- 用JQuery 判断某个属性是否存在hasAttr的解决方法 - Web前端
- jquery清空textarea等输入框实现代码 - 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属性


