【码在江湖】前端少侠的json故事(下):jsonp的应用
jsonp的应用


话说天下大势,分久必合,合久必分,代码江湖自进入21世纪以来,前后端分离成为了大势所趋,代码分工更为精细,更为深入,而正所谓码在江湖,身不由己,为了更好的实现需求,程序猿们必须不断学习新的知识,从此踏上了每天给自己挖坑给别人填坑的不归路。
说回正事,上回说到前端少侠dk懂得了一点ng的皮毛功夫就和后端进行数据对接,殊不知get()方法获取json数据失败,究竟是什么原因造成的呢?
跨域访问
当时,我跟樟哥说:樟哥,这次肯定可以的!
然而发送请求的时候就没有数据返回,页面根本没有响应,按下f12,发现network的response报了一条错误,在console里看,返回一条错误信息:
Uncaught SyntaxError: Unexpected token ://谷歌浏览器
SyntaxError: missing ; before statement//火狐浏览器
经查实,这其实是一个跨域访问的错误,什么是跨域访问呢?据一位江湖人士的解答,大概就是这样的:
- 如果在A网站中,我们希望使用Ajax来获得B网站中的特定内容
- 如果A网站与B网站不在同一个域中,那么就出现了跨域访问问题
- Ajax的跨域访问问题是现有的Ajax开发人员比较常遇到的问题
- 一般都会用jsonp方法来解决
于是,我又屁颠屁颠地去找jsonp()了。
寻找ng的jsonp()
网上关于ng的jsonp()说的非常的零散,以至于我把网上关于ng的jsonp()的内容都看了一遍,这一遍便是一整个下午。
网上关于jquery的jsonp倒是挺全的,不过ng的信息就差太远了。
那天下午,我被忽悠把get()换成jsonp(),然后在请求的后面加上一个参数'callback' : 'JSON_CALLBACK':
$http.jsonp("localhost:8080/dkplus",{
params:{
'callback' : 'JSON_CALLBACK',
'tag' : 0,
'id' : 1
}
})
.success(function(data, status, header, config) {
$scope.items = data.data;
})
.error(function(data, status, header, config){
console.log('json解析错误');
})
一开始倒是挺奏效的,我看到response里面返回了一堆json对象,而且都解析出来了,然而还是不走success()方法,走了error()方法。
后来根据网上零零散散的信息,我得知这个需要后端配合,返回的数据格式必须是回调函数名+(+json+),当时看到这个就懵了,大哥你要是给个实例该多好,像我这种初次接触jsonp的人不一定看的懂的。
那时候套用了这个方法还是不行,因为总感觉缺点什么,后来再看一遍,他所说的调用回调函数我并没有定义,于是我就在加一个回调函数JSON_CALLBACK()。
历时一个下午,jsonp()跨域访问终于成功了。
ng的jsonp()最终方案
这里总结一下思路:
使用
jsonp()解决跨域访问,必须在请求的地址后加上参数'callback' : 'JSON_CALLBACK':$http.jsonp("localhost:8080/dkplus",{ params:{ 'callback' : 'JSON_CALLBACK', 'tag' : 0, 'id' : 1 } }) .success(function(data, status, header, config) { $scope.items = data.data; }) .error(function(data, status, header, config){ console.log('json解析错误'); })在js里定义一个方法
JSON_CALLBACK(),用于解析后端返回的数据window.JSON_CALLBACK = function(data){ $scope.items = data.data; }- 后端返回的数据格式为
回调函数名+(+json+)
例如json为:
{ "code": 0, "msg": "返回正常", "data": [ { "content": "你好世界", "stu_name": "dk", "ismyself": 0, "all_hole_id": 8, "release_time": "2016-11-25 20:09:57", "praise_nums": 0 }, { "content": "hello world!", "stu_name": "dk", "ismyself": 0, "all_hole_id": 9, "release_time": "2016-11-25 20:10:03", "praise_nums": 0 } }那么后端应该返回这样的数据
JSON_CALLBACK({ "code": 0, "msg": "返回正常", "data": [ { "content": "你好世界", "stu_name": "dk", "ismyself": 0, "all_hole_id": 8, "release_time": "2016-11-25 20:09:57", "praise_nums": 0 }, { "content": "hello world!", "stu_name": "dk", "ismyself": 0, "all_hole_id": 9, "release_time": "2016-11-25 20:10:03", "praise_nums": 0 } })
这样就可以正常接收和解析json数据了,但是,要注意的是
- 这时候仍然是不走success()方法的
- 之所以能接收和解析数据,是因为它走的是我们定义的回调函数JSON_CALLBACK(),所以得到数据后对数据的操作还得在这个方法里定义。
微信公众号dkplus,由前端少侠dk搭建的分享平台,主攻web前端,但也游离于设计,乐于分享他的代码故事、ps技巧和ppt技巧。码在江湖,身不由己,珍爱生命,简约设计,我是前端,也是设计。博客园:http://www.cnblogs.com/dkplus/
【码在江湖】前端少侠的json故事(下):jsonp的应用的更多相关文章
- 【码在江湖】前端少侠的json故事(上)日月第一击
日月第一击 这是我前端生涯第一次和后台对接,其经历真是苦不堪言,多次绝处逢生,柳暗花明,可就是迟迟见不到那条村子.当然,最后我还是完成了这次对接.下面来聊一聊我这白痴一般的经历. 序章 话说天下大势, ...
- 【码在江湖】前端少侠的json故事(中)ng的json
ng的json 正所谓"人在江湖,身不由己",在开发之路上前端少侠dk遇到过种种困难,尤其在与后端进行数据对接的时候,不得不逼迫自己以极快的速度去学习和掌握一些奇招怪式,正当他以为 ...
- 前端少侠的ps故事
前端少侠的ps故事 正所谓,码在江湖,身不由己.自21世纪前后端分离,代码分工细化以来,前端与设计的合作也变得越来越重要.有人说,如果前端懂设计的话,工作会更快一点.倘若说我入前端半年能算半个前端少侠 ...
- 正确的前端传后台json方式
DEMO: var data=JSON.stringify({"page": {"pagenow": 1,"pagesize": 20},& ...
- arguments.callee 调用函数自身用法----JSON.parse()和JSON.stringify()前端js数据转换json格式
arguments.callee 调用函数自身用法 arguments.callee 在哪一个函数中运行,它就代表哪个函数. 一般用在匿名函数中. 在匿名函数中有时会需要自己调用自己,但是由于是匿名函 ...
- SpringMVC 前端获得定义JSON对象的方法
SpringMVC 前端获得定义JSON对象的方法: 可以使用map进行对象的创建,这样就会解析成键值对,不需要为前端专门定义对象.
- java后端无法接收到前端传递的json对象
java后端无法接收到前端传递的json对象 一·可能是因为未使用@RequestBody 在Controller层中,要么使用@RestController要么使用@Controller+@@Req ...
- jdk1.8源码包下载并导入到开发环境下助推高质量代码(Eclipse、MyEclipse和Scala IDEA for Eclipse皆适用)(图文详解)
不多说,直接上干货! jdk1.8 源码, Linux的同学可以用的上. 由于源码JDK是前版本的超集, 所以1.4, 1.5, 1.6, 1.7都可以用的上. 其实大家安装的jdk路径下,这 ...
- Spring MVC 后端获取前端提交的json格式字符串并直接转换成control方法对应的参数对象
场景: 在web应用开发中,spring mvc凭借出现的性能和良好的可扩展性,导致使用日渐增多,成为事实标准,在日常的开发过程中,有一个很常见的场景:即前端通过ajax提交方式,提交参数为一个jso ...
随机推荐
- 解析大型.NET ERP系统 权限模块设计与实现
权限模块是ERP系统的核心模块之一,完善的权限控制机制给系统增色不少.总结我接触过的权限模块,以享读者. 1 权限的简明定义 ERP权限管理用一句简单的话来说就是:谁 能否 做 那些 事. 文句 含义 ...
- 【.NET深呼吸】基础:自定义类型转换
照例,老周在开始吹牛之前,先讲讲小故事,这是朋友提出的建议,老TMD写技术有什么了不起的,人人都会写.后来老周想想,也确实,代码谁不会写,能写到有品位有感悟,就不容易做到.于是,老周接受了该朋友的建议 ...
- ElasticSearch 5学习(4)——简单搜索笔记
空搜索: GET /_search hits: total 总数 hits 前10条数据 hits 数组中的每个结果都包含_index._type和文档的_id字段,被加入到_source字段中这意味 ...
- ASP.NET MVC5+EF6+EasyUI 后台管理系统(5)-EF增删改查
系列目录 前言 为了符合后面更新后的重构系统,文章于2016-11-1日重写 回顾上一节的解决方案,我们看出了解决方案中类库的关系 这里要说明一点MVC!=三层 他们大约是这样的一种关系 代码实现 上 ...
- 常用数据结构-线性表及Java 动态数组 深究
[Java心得总结六]Java容器中——Collection在前面自己总结的一篇博文中对Collection的框架结构做了整理,这里深究一下Java中list的实现方式 1.动态数组 In compu ...
- AJAX(一)
AJAX(一) Ajax是Asynchronous Javascript和XML的简写,这一技术能够向服务器请求额外的数据而无需卸载页面,会带来更好的用户体验. [前面的基础知识][关于同步和异步的了 ...
- 利用WCF的双工通讯实现一个简单的心跳监控系统
何为心跳监控系统? 故名思义,就是监控某个或某些个程序的运行状态,就好比医院里面的心跳监视仪一样,能够随时显示病人的心跳情况. 心跳监控的目的是什么? 与医院里面的心跳监视仪目的类似,监控程序运行状态 ...
- Design Patterns Simplified - Part 3 (Simple Factory)【设计模式简述--第三部分(简单工厂)】
原文链接:http://www.c-sharpcorner.com/UploadFile/19b1bd/design-patterns-simplified-part3-factory/ Design ...
- asp.net DataTable导出Excel 自定义列名
1.添加引用NPOI.dll 2.cs文件头部添加 using NPOI.HSSF.UserModel; using NPOI.SS.UserModel; using System.IO; 3.代码如 ...
- C#开发微信门户及应用(2)--微信消息的处理和应答
微信应用如火如荼,很多公司都希望搭上信息快车,这个是一个商机,也是一个技术的方向,因此,有空研究下.学习下微信的相关开发,也就成为计划的安排事情之一了.本系列文章希望从一个循序渐进的角度上,全面介绍微 ...