angular.js - angular1如何使用跨域后的得到的數(shù)據(jù)
問題描述
`
在jquery中跨域是可以在success函數(shù)中使用跨域得到的數(shù)據(jù)的,原理是利用script便簽的src可以跨域,把url加上?callback=func; func是jq加的一個臨時的全局函數(shù)...`
angular中百度了半天找到這張圖片,教程上說url加上callback=JSON_CALLBACK后(一定要寫成JSON_CALLBACK),這樣當服務器響應后,success函數(shù)會執(zhí)行,然而我照做一遍報錯了!
然后我把代碼改成這樣,沒有報錯,跨域成功,但是ajax是異步的,如何在angular的controller中使用得到的數(shù)據(jù)呢?
問題解答
回答1:jsonp,服務器端是根據(jù)你后面callback的函數(shù)名,給你返回一段包裝的json數(shù)據(jù),并不一定就是JSON_CALLBACK,名字可以自己隨便取,但是你的js文件里面要有與之保持一致的函數(shù)名,你可以看一下這一篇文章jsonp
回答2:要在后臺設置跨域,所以和angular跨域沒什么關系。。。
回答3:有很多種方法,優(yōu)雅一點的,創(chuàng)建一個factory,或者service,whatever,返回一個對象,factory或service里異步請求數(shù)據(jù),返回的數(shù)據(jù)存儲到返回的對象下,屬性名隨你起,然后吧這個玩意注入到你想使用的controller里,但是因為是異步的,所以controller執(zhí)行的時候可能返回的對象還是空,需要bind到$scope上才能自動更新。要不你可以隨意一點,直接在controller里異步執(zhí)行,回調(diào)里直接給到$scope上。如果異步的數(shù)據(jù)需要第一時間展現(xiàn),還是先執(zhí)行異步,回調(diào)里初始化angular吧。
相關文章:
1. javascript - angular使從elastichearch中取出的文本高亮顯示,如圖所示2. python bottle跑起來以后,定時執(zhí)行的任務為什么每次都重復(多)執(zhí)行一次?3. javascript - 求幫助 , ATOM不顯示界面!!!!4. 視頻文件不能播放,怎么辦?5. 前端 - 誰來解釋下這兩個 CSS selector 區(qū)別6. python - 爬蟲模擬登錄后,爬取csdn后臺文章列表遇到的問題7. mysql - 分庫分表、分區(qū)、讀寫分離 這些都是用在什么場景下 ,會帶來哪些效率或者其他方面的好處8. javascript - vue2如何獲取v-model變量名9. html5 - HTML代碼中的文字亂碼是怎么回事?10. javascript - ios返回不執(zhí)行js怎么解決?
