Форум программистов, компьютерный форум, киберфорум
Angular/AngularJS
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.92/13: Рейтинг темы: голосов - 13, средняя оценка - 4.92
0 / 0 / 0
Регистрация: 06.02.2018
Сообщений: 6

Динамическое отображение изменение переменной

16.12.2018, 12:11. Показов 2639. Ответов 1
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Доброе время суток друзья! Помогите решить проблемку. Совсем не шарю в Angular, но на работе дали тестовое задание от другой фирмы на сотрудничество, и по не понятным для меня причинам, руководство повесило angular на меня, хотя я бэкэндщик... В общем, задание такое: Есть поле ввода (input type text), есть кнопка (submit), есть обычный div, где выводится информация. Цель такая: при вводе числа, по нажатию на кнопку, в диве обновляется это число. НО!!!! Не всё так просто. Число должно выводиться динамически. Например: Было 100 В диве, а мы ввели 200 и нажали на кнопку, так вот, ЗА СЕКУНДУ, число в диве должно меняться с 100 до 200. Т.е. 101 - 102 - 103 - ... - 199 - 200. Подчеркиваю, за секунду! Далее если мы вводим новое число, например 50, оно аналогичным образом должно меняться с 200 до 50, ну т.е. 199 - 198 - ... - 51 - 50, опять же за секунду. На данный момент, всего что я достиг, это: просто отображение нового введенного числа, без этой бесовской анимации

Вот код:

файл app.component.html
HTML5
1
2
3
4
5
6
<p>Введите число:</p>
<input type="text" [(ngModel)]="message">
<button (click)="refresh()">Обновить</button>
<div>
    <h2>{{result}}</h2>
</div>
файл app.component.ts:
JavaScript
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
import { Component } from '@angular/core';
 
@Component({
  selector: 'app-root',
  templateUrl: './app.component.html',
  styleUrls: ['./app.component.css']
})
export class AppComponent {
    result;
    message;
    
    refresh(){
        this.result = this.message;
    }
}
Помогите плиз. Хотя бы подскажите, в какую сторону копать? Пробовал пользоваться SetInterval, но успеха не достиг, т.к. тупо не смог его остановить...
0
Лучшие ответы (1)
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
16.12.2018, 12:11
Ответы с готовыми решениями:

Динамическое изменение переменной
Доброго дня! Вопрос следующий - возможно ли динамическое присваивание переменной php значения переменной javascript (изменилось значение...

Динамическое изменение переменной LESS
Хай! Вот так я меняю переменную с помощью jquery: less.modifyVars({'@color': value}); - работает с багом! Изменяя переменную с less...

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

1
2 / 1 / 1
Регистрация: 16.12.2018
Сообщений: 1
16.12.2018, 12:14
Лучший ответ Сообщение было отмечено Mister_Freeman как решение

Решение

Используй SetTimeout с разными интервалами. И неплохо было бы сделать проверку на число. Результат такой:

app.component.ts:

JavaScript
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
import { Component } from '@angular/core';
 
@Component({
  selector: 'app-root',
  templateUrl: './app.component.html',
  styleUrls: ['./app.component.css']
})
export class AppComponent {
    result = 0;
    message;
    flash;
    step = [];
    
    refresh(){
        if(!isNaN(this.message)){
            if(this.message >= this.result){
                this.flash = (this.message - this.result)/5;
                this.step[1] = this.message - (this.flash * 4);
                this.step[2] = this.message - (this.flash * 3);
                this.step[3] = this.message - (this.flash * 2);
                this.step[4] = this.message - this.flash;
                this.step[5] = this.message - 0;
            }
            else{
                this.flash = (this.result - this.message)/5;
                this.step[1] = this.result - (this.flash * 4);
                this.step[2] = this.result - (this.flash * 3);
                this.step[3] = this.result - (this.flash * 2);
                this.step[4] = this.result - this.flash;
                this.step[5] = this.message - 0; 
            }
            setTimeout(() => {
                this.result = this.step[1];
                this.result = this.result.toFixed(2);
            }, 100)
            setTimeout(() => {
                this.result = this.step[2];
                this.result = this.result.toFixed(2);
            }, 200)
            setTimeout(() => {
                this.result = this.step[3];
                this.result = this.result.toFixed(2);
            }, 300)
            setTimeout(() => {
                this.result = this.step[4];
                this.result = this.result.toFixed(2);
            }, 400)
            setTimeout(() => {
                this.result = this.step[5];
                this.result = this.result.toFixed(2);
            }, 500)
        }
    }
}
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
16.12.2018, 12:14
Помогаю со студенческими работами здесь

Динамическое изменение значения переменной с соответствующей корректировкой графиков
Привет! Допустим строю простой график: A = 1 x = 0:0.01:10 y = A * sin(x) plot(x,y) Теперь я хочу какую - то крутилку...

Изменение значения переменной, название которой находится в текстовой переменной
Подскажите как мне сделать: у меня есть цикл _0_gray = 1 for i in range(9): peremen = &quot;_&quot; + str(i) + &quot;_gray&quot;\ ...

Изменение переменной цикла (изменение части пути)
Есть желание упростить жизнь, но что то с реализацией туговато:). Есть каталог с файлами для отправки формата...

Динамическое отображение графика
Доброго времени суток жители данного форума и гости ! Имеется следущая задача -- есть данные которые с определенной дискретностью...

Динамическое отображение изображений
Помогите, а то я в ступоре. Вообщем какова задача: Сервер возвращает json с урлами изображений. Я их заганяю в arraylist. Есть адаптер...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
Подстановка значения реквизита справочника в табличную часть документа
Maks 10.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: при выборе сотрудника (справочник Сотрудники) в ТЧ документа. . .
Очистка реквизитов документа при копировании
Maks 09.04.2026
Алгоритм из решения ниже применим как для типовых, так и для нетиповых документов на самых различных конфигурациях. Задача: при копировании документа очищать определенные реквизиты и табличную. . .
модель ЗдравоСохранения 8. Подготовка к разному выполнению заданий
anaschu 08.04.2026
https:/ / github. com/ shumilovas/ med2. git main ветка * содержимое блока дэлэй из старой модели теперь внутри зайца новой модели 8ATzM_2aurI
Блокировка документа от изменений, если он открыт у другого пользователя
Maks 08.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа, разработанного в конфигурации КА2. Задача: запретить редактирование документа, если он открыт у другого пользователя. / / . . .
Система безопасности+живучести для сервера-слоя интернета (сети). Двойная привязка.
Hrethgir 08.04.2026
Далее были размышления о системе безопасности. Сообщения с наклонным текстом - мои. А как нам будет можно проверить, что ссылка наша, а не подделана хулиганами, которая выбросит на другую ветку и. . .
Модель ЗдрввоСохранения 7: больше работников, больше ресурсов.
anaschu 08.04.2026
работников и заданий может быть сколько угодно, но настроено всё так, что используется пока что только 20% kYBz3eJf3jQ
Дальние перспективы сервера - слоя сети с космологическим дизайном интефейса карты и логики.
Hrethgir 07.04.2026
Дальнейшее ближайшее планирование вывело к размышлениям над дальними перспективами. И вот тут может быть даже будут нужны оценки специалистов, так как в дальних перспективах всё может очень сильно. . .
Горе от ума
kumehtar 07.04.2026
Эта мне ментальная установка, что вот прямо сейчас, мол, мне для полного счастья не хватает (нужное вписать), и когда я этого достигну - тогда и полный кайф. Одна из самых сильных ловушек на пути. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru