WedX - журнал о программировании и компьютерных науках

Почему я получаю эту ошибку в angularJS после выполнения ng-include?

Я решил разбить html на модули и поместить часть его в другой html.

<div ng-include="'file.html'"></div>

Когда я запускаю приложение, файл file.html загружается, но в консоли я получаю эту ошибку:

10 $digest() iterations reached. Aborting!
Watchers fired in the last 5 iterations: []

Я не знаю, что не так.

Вся ошибка здесь:

angular.min.js:1 Uncaught Error: [$rootScope:infdig] 10 $digest() iterations reached. Aborting!
Watchers fired in the last 5 iterations: []
https://errors.angularjs.org/1.3.9/$rootScope/infdig?p0=10&p1=%5B%5D
    at angular.min.js:1
    at l.$digest (angular.min.js:3)
    at l.$apply (angular.min.js:3)
    at g (angular.min.js:2)
    at x (angular.min.js:2)
    at XMLHttpRequest.m.onload (angular.min.js:2)
(anonymous) @ angular.min.js:1
$digest @ angular.min.js:3
$apply @ angular.min.js:3
g @ angular.min.js:2
x @ angular.min.js:2
m.onload @ angular.min.js:2

  • если я удалю этот ng-include, ошибка не появится! 27.03.2017
  • Вот ваше решение 27.03.2017
  • вам нужно поделиться своим кодом 27.03.2017
  • @tanmay просто потому, что ng-include генерирует эту ошибку, код работает нормально с ошибкой или без нее, но ошибка есть. 27.03.2017

Ответы:


1

Убедитесь, что путь, на который вы ссылаетесь в ngInclude, действителен, иначе вы получите бесконечный цикл дайджеста.

27.03.2017
  • это невозможно, потому что файл наконец включен. 27.03.2017

  • 2

    Эта ошибка возникает, когда путь к файлу .html неверен. Итак, проверьте, доступен ли файл и находится ли он в нужном месте.

    27.03.2017
  • это невозможно, потому что файл наконец включен. 27.03.2017

  • 3

    Включаемый вами файл содержит код, который дает неповторяемые результаты.

    AngularJS попытается вычислить все наблюдаемые выражения дважды. Если результаты различаются, он будет продолжать вычислять их снова и снова до 10 раз, пока не получит одно и то же дважды подряд.

    Эта ошибка означает, что какой-то наблюдаемый код не дал один и тот же результат дважды в течение ограничения в 10 вызовов. Это происходит, например, если отслеживаемые выражения используют функции, которые возвращают случайные результаты или изменяют внутреннее состояние. Убедитесь, что все отслеживаемые выражения (включая выражения директив) являются чистыми, т.е. не влияет на внутреннее состояние приложения, а только извлекает значения.

    27.03.2017

    4

    Самое быстрое решение выяснить, какая часть вашего приложения вызывает такое поведение:

    1. Удалите все подозрительные HTML-коды — в основном удалите весь свой HTML-код из шаблона и проверьте, нет ли предупреждений.

    2.Если предупреждений нет - добавьте небольшие части удаленного html и проверьте, вернулась ли проблема

    3. повторяйте шаг 2, пока не получите предупреждение - вы поймете, какая часть вашего html отвечает за проблему

    4. исследовать дальше - часть из шага 3 отвечает либо за изменение объектов в $scope, либо за возврат неидентичных объектов в каждом цикле $digest.

    5. Если после шага 1 у вас все еще есть предупреждения об итерации $digest, то вы, вероятно, делаете что-то очень подозрительное. Повторите те же шаги для родительского шаблона/области/контроллера.

    Вы также хотите убедиться, что вы не изменяете ввод ваших пользовательских фильтров.

    Имейте в виду, что в JavaScript есть определенные типы объектов, которые ведут себя не так, как вы обычно ожидаете:

    new Boolean(true) === new Boolean(true) // false
    new Date(0) == new Date(0) // false
    new String('a') == new String('a') // false
    new Number(1) == new Number(1) // false
    [] == [] // false
    new Array == new Array // false
    ({})==({}) // false
    

    а также проверьте это

    <ng-include src=" 'pathto/file.html' "></ng-include>
    
    27.03.2017
    Новые материалы

    Как создать диаграмму градиентной кисти с помощью D3.js
    Резюме: Из этого туториала Вы узнаете, как добавить градиентную кисть к диаграмме с областями в D3.js. Мы добавим градиент к значениям SVG и применим градиент в качестве заливки к диаграмме с..

    Я хотел выучить язык программирования MVC4, но не мог выучить его раньше, потому что это выглядит сложно…
    Просто начните и учитесь самостоятельно Я хотел выучить язык программирования MVC4, но не мог выучить его раньше, потому что он кажется мне сложным, и я бросил его. Это в основном инструмент..

    Лицензии с открытым исходным кодом: руководство для разработчиков и создателей
    В динамичном мире разработки программного обеспечения открытый исходный код стал мощной парадигмой, способствующей сотрудничеству, инновациям и прогрессу, движимому сообществом. В основе..

    Объяснение документов 02: BERT
    BERT представил двухступенчатую структуру обучения: предварительное обучение и тонкая настройка. Во время предварительного обучения модель обучается на неразмеченных данных с помощью..

    Как проанализировать работу вашего классификатора?
    Не всегда просто знать, какие показатели использовать С развитием глубокого обучения все больше и больше людей учатся обучать свой первый классификатор. Но как только вы закончите..

    Работа с цепями Маркова, часть 4 (Машинное обучение)
    Нелинейные цепи Маркова с агрегатором и их приложения (arXiv) Автор : Бар Лайт Аннотация: Изучаются свойства подкласса случайных процессов, называемых дискретными нелинейными цепями Маркова..

    Crazy Laravel Livewire упростил мне создание электронной коммерции (панель администратора и API) [Часть 3]
    Как вы сегодня, ребята? В этой части мы создадим CRUD для данных о продукте. Думаю, в этой части я не буду слишком много делиться теорией, но чаще буду делиться своим кодом. Потому что..


    Для любых предложений по сайту: [email protected]