Angularjs ios9$rootScope上的角度路由:infdig错误
在ios8中工作的angular应用程序中进行路由,在ios9中产生[$rootScope:infdig]错误。我尝试了Angularjs ios9$rootScope上的角度路由:infdig错误,angularjs,webview,ios9,Angularjs,Webview,Ios9,在ios8中工作的angular应用程序中进行路由,在ios9中产生[$rootScope:infdig]错误。我尝试了ngRoute和ui.router,但结果是一样的 Error: [$rootScope:infdig] http://errors.angularjs.org/1.4.3/$rootScope/infdig?p0=10&p1=%5B%5D 有什么解决办法吗?这个答案基于Angular v1.4.3 diff --git a/src/ng/browser.js b/s
ngRoute
和ui.router
,但结果是一样的
Error: [$rootScope:infdig] http://errors.angularjs.org/1.4.3/$rootScope/infdig?p0=10&p1=%5B%5D
有什么解决办法吗?这个答案基于Angular v1.4.3
diff --git a/src/ng/browser.js b/src/ng/browser.js
index 928de95..3b9957e 100644
--- a/src/ng/browser.js
+++ b/src/ng/browser.js
@@ -87,7 +87,9 @@ function Browser(window, document, $log, $sniffer) {
var cachedState, lastHistoryState,
lastBrowserUrl = location.href,
baseElement = document.find('base'),
- reloadLocation = null;
+ reloadLocation = null,
+ pendingHref = null,
+ pendingHrefTimer = null;
cacheState();
lastHistoryState = cachedState;
@@ -124,6 +126,18 @@ function Browser(window, document, $log, $sniffer) {
if (location !== window.location) location = window.location;
if (history !== window.history) history = window.history;
+ // Schedule cleaning up pendingHref on the next run loop for setting URL. This is to handle
+ // the case where the browser doesn't update the location.* properties immediately
+ if (!pendingHrefTimer && pendingHref && url) {
+ pendingHrefTimer = setTimeout(function () {
+ if (location.href == pendingHref) {
+ console.log('Actual href updated... setting pendingHref to null from setTimeout');
+ pendingHref = null;
+ }
+ pendingHrefTimer = null;
+ }, 0);
+ }
+
// setter
if (url) {
var sameState = lastHistoryState === state;
@@ -147,6 +161,7 @@ function Browser(window, document, $log, $sniffer) {
// Do the assignment again so that those two variables are referentially identical.
lastHistoryState = cachedState;
} else {
+ pendingHref = url;
if (!sameBase || reloadLocation) {
reloadLocation = url;
}
@@ -161,10 +176,22 @@ function Browser(window, document, $log, $sniffer) {
return self;
// getter
} else {
+ var href = location.href.replace(/%27/g, "'");
+ if (pendingHref) {
+ //console.log('.. using pendingHref for url() return value');
+ href = pendingHref;
+ }
+
+ if (location.href == pendingHref) {
+ console.log('Actual href updated... setting pendingHref to null in getter');
+ pendingHref = null;
+ }
+
+ //var href = location.href.replace(/%27/g,"'");
// - reloadLocation is needed as browsers don't allow to read out
// the new location.href if a reload happened.
// - the replacement is a workaround for https://bugzilla.mozilla.org/show_bug.cgi?id=407172
- return reloadLocation || location.href.replace(/%27/g,"'");
+ return reloadLocation || href;
}
};
显然解决了这个问题,但在Angular的其他版本中没有解决。即使这被标记为此问题的副本。这是解决这个问题的最好办法 这篇文章中选择的答案将引导您转到这个插件,它用angular来修补iOS9的所有问题。
此修补程序适用于
Angular 1.2.0–1.4.5
和所有较新版本的Angular都将嵌入此修复程序。发现此链接已打开雷达,因此似乎还没有修复程序。Angular github上另一个有问题的链接仍然没有解决方案。