angular.js - angular1如何使用跨域后的得到的数据
问题描述
`
在jquery中跨域是可以在success函数中使用跨域得到的数据的,原理是利用script便签的src可以跨域,把url加上?callback=func; func是jq加的一个临时的全局函数...`
angular中百度了半天找到这张图片,教程上说url加上callback=JSON_CALLBACK后(一定要写成JSON_CALLBACK),这样当服务器响应后,success函数会执行,然而我照做一遍报错了!
然后我把代码改成这样,没有报错,跨域成功,但是ajax是异步的,如何在angular的controller中使用得到的数据呢?
问题解答
回答1:jsonp,服务器端是根据你后面callback的函数名,给你返回一段包装的json数据,并不一定就是JSON_CALLBACK,名字可以自己随便取,但是你的js文件里面要有与之保持一致的函数名,你可以看一下这一篇文章jsonp
回答2:要在后台设置跨域,所以和angular跨域没什么关系。。。
回答3:有很多种方法,优雅一点的,创建一个factory,或者service,whatever,返回一个对象,factory或service里异步请求数据,返回的数据存储到返回的对象下,属性名随你起,然后吧这个玩意注入到你想使用的controller里,但是因为是异步的,所以controller执行的时候可能返回的对象还是空,需要bind到$scope上才能自动更新。要不你可以随意一点,直接在controller里异步执行,回调里直接给到$scope上。如果异步的数据需要第一时间展现,还是先执行异步,回调里初始化angular吧。
相关文章:
1. javascript - 修改表单多选项时和后台同事配合的问题。2. mysql - 索引过滤性不好是由什么原因引起的,应该怎么解决3. javascript - vue生成一维码?求助!!!!!急4. javascript - H5页面怎么查看console信息?5. android - Listview模仿朋友圈点赞的TextView没有刷新?6. dockerfile - [docker build image失败- npm install]7. mysql - 我的myeclipse一直连显示数据库连接失败,不知道为什么8. docker内创建jenkins访问另一个容器下的服务器问题9. 网页爬虫 - Python:爬虫的中文编码问题?10. angular.js - angularjs 怎么封装 upload 上传
