angular.js - angularJS怎么實現(xiàn)請求的數(shù)據(jù)還未加載完成時展示“正在加載”的提示?
問題描述
在點擊button發(fā)出請求后,由于網(wǎng)絡(luò)或者數(shù)據(jù)較大的原因,頁面中的angularJS雙向綁定數(shù)據(jù)部分不顯示,頁面結(jié)構(gòu)很難看,怎么能實現(xiàn)在所有的數(shù)據(jù)加載完成之前,彈出層覆蓋掉原網(wǎng)頁并且提示“正在加載”,等所有的數(shù)據(jù)加載完成之后,再顯示帶有完整數(shù)據(jù)的網(wǎng)頁。如下面的效果:
問題解答
回答1:https://github.com/cgross/angular-busy/blob/master/README.md 使用這個模塊
回答2:事先做好遮罩層,發(fā)起請求時(一般都是 $http 或 $resource)顯示遮罩,promise resolve 后關(guān)閉遮罩。
邏輯就是這么簡單,但是因為出現(xiàn)的很頻繁所以要考慮如何 DRY。
視圖層面上,如果遮罩是全應(yīng)用通用的就不要每個 route 里都寫一遍,而是考慮寫在比較上層的路由入口,讓子路由共享。
調(diào)用層面,簡單一點把遮罩狀態(tài)保存在 $rootScope,使用 DI 來隨取隨用;講究一點就寫個 service 來控制。
遮罩本身可以封裝成 directive 便于復(fù)用,不過這東西很簡單,不封裝也罷。
相關(guān)文章:
1. Docker for Mac 創(chuàng)建的dnsmasq容器連不上/不工作的問題2. docker安裝后出現(xiàn)Cannot connect to the Docker daemon.3. docker - 如何修改運行中容器的配置4. python3.x - python連oanda的模擬交易api獲取json問題第五問5. nignx - docker內(nèi)nginx 80端口被占用6. css3 - 沒明白盒子的height隨width的變化這段css是怎樣實現(xiàn)的?7. javascript - webpack熱加載配置不生效8. javascript - QWebEngineView 如何爬 angular 的動態(tài)數(shù)據(jù)?9. java - SSH框架中寫分頁時service層中不能注入分頁類10. java - instance method中 static后的<K>是什么意思?
