golovewkin
@golovewkin
WEB - Разработчик

Как перенаправить на главную Angular?

Всем привет!
На ссылке
angular.js-example/#
показывается список задач

На ссылке
angular.js-example/#/tasks/12
показывается детальное описание задачи

Чтобы возвращаться на главную сделал директиву
taskApp.directive('backButton', function ($location) {
    return {
        restrict: 'A',
        link: function (scope, element, attrs) {
            element.on('click', function () {
                $location.url('/')
            });
        }
    };
});

По идее должно должно редиректить на главную.
Почему не работает?
Можно, конечно, написать history.back() но тогда те, кто пришел через angular.js-example/#/tasks/12 будут уходить с сайта
Спасибо
  • Вопрос задан
  • 619 просмотров
Решения вопроса 2
1. Зачем вы вешаете event через DOM?
Повесьте через ng-click.
2. Попробуйте $location.path('/');
3. Я понимаю что вы это для обучения делаете, но лучше сразу начинать пользоваться angular-ui-router, т.к. там есть много очень нужного функционала.
Ответ написан
golovewkin
@golovewkin Автор вопроса
WEB - Разработчик
сам догнал.
Нужно вызвать цикл $digest

Итого рабочий код
taskApp.directive('backButton', function ($location) {
    return {
        restrict: 'A',
        link: function (scope, element, attrs) {
            element.on('click', function () {
                $location.path('/');
		scope.$apply();
            });
        }
    };
});
Ответ написан
Комментировать
Пригласить эксперта
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Похожие вопросы
CodeX Нижний Новгород
от 30 000 до 80 000 ₽
CodeX Нижний Новгород
от 30 000 до 80 000 ₽
Uptrade Москва
от 120 000 до 200 000 ₽
26 нояб. 2024, в 13:05
450 руб./в час
26 нояб. 2024, в 12:58
30000 руб./за проект
26 нояб. 2024, в 12:56
1500 руб./в час