Форум программистов, компьютерный форум, киберфорум
JavaScript
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.75/4: Рейтинг темы: голосов - 4, средняя оценка - 4.75
 Аватар для Liori
4 / 4 / 5
Регистрация: 30.08.2012
Сообщений: 155

Как сократить код?

09.07.2015, 12:12. Показов 842. Ответов 10
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
У меня есть объект Worker и 6 экземпляров этого объекта.
Нужно с новой строчки выводить все значения свойств каждого экземпляра. Мой код такой:
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
function Worker(name, age, payment)
{
    this.name=name;
    this.age=age;
    this.payment=payment;
}
var amount = 6;
var work1 = new Worker("Mihail", 23, 10000);
var work2 = new Worker("Artem", 22, 12000);
var work3 = new Worker("Anna", 22, 14000);
var work4 = new Worker("Pavel", 24, 15000);
var work5 = new Worker("Karina", 23, 11000);
var work6 = new Worker("Vladimir", 21, 12000);
document.write("<br /><strong>There are "+amount+" workers:</strong> <br /><br />");
 
for(var j in work1)
{
    document.write(work1[j] + " ");
}
document.write("<br /><br />");
for(var j in work2)
{
    document.write(work2[j] + " ");
}
document.write("<br /><br />");
for(var j in work3)
{
    document.write(work3[j] + " ");
}
document.write("<br /><br />");
for(var j in work4)
{
    document.write(work4[j] + " ");
}
document.write("<br /><br />");
for(var j in work5)
{
    document.write(work5[j] + " ");
}
document.write("<br /><br />");
for(var j in work6)
{
    document.write(work6[j] + " ");
}
Можно ли это всё как-то в одном цикле сделать? И ещё желательно чтобы была нумерация людей.
1
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
09.07.2015, 12:12
Ответы с готовыми решениями:

Сократить код
Доброго времени суток. Есть такое задание: по значениям из заполненной формы строится процентная диаграмма. Код у меня, хоть и довольно...

Сократить JS-код
Добрый день. Как можно сократить этот JS-код? $(document).ready(function(){ $(&quot;.btn-mymodal&quot;).click(function() { ...

Можно ли сократить код?
Хочу создать форму через js. Есть вариант покороче? var body = document.body, form = document.createElement( 'form' ), input1 =...

10
126 / 113 / 56
Регистрация: 05.12.2012
Сообщений: 463
09.07.2015, 12:15
объявите work как amount-элементный массив, а потом
JavaScript
1
2
3
4
5
6
for (var i = 0; i < amount; i++){
    for(var j in work[i]){
        document.write(work[i][j] + " ");
    }
    document.write("<br /><br />");
}
1
 Аватар для Liori
4 / 4 / 5
Регистрация: 30.08.2012
Сообщений: 155
09.07.2015, 12:20  [ТС]
kushok, Спасибо. А можно это как-то реализовать, не объявляя массив, а только работая с экземплярами объекта?
0
126 / 113 / 56
Регистрация: 05.12.2012
Сообщений: 463
09.07.2015, 12:28
На мой некомпетентный взгляд, нет)
У вас набор однотипных элементов, массив так и просится)
И нумирация есть, как Вы и хотели:
JavaScript
1
2
3
4
5
6
7
for (var i = 0; i < amount; i++){
    document.write("Worker number " + (i+1) + ":");
    for(var j in work[i]){
        document.write(work[i][j] + " ");
    }
    document.write("<br /><br />");
}
0
 Аватар для Liori
4 / 4 / 5
Регистрация: 30.08.2012
Сообщений: 155
09.07.2015, 12:40  [ТС]
kushok, т.е. Worker объявить как вот такой массив?

JavaScript
1
var WorkerArray = [ ["Mihail", 23, 10000], ["Artem", 22, 12000], ["Anna", 22, 14000], ["Pavel", 24, 15000], ["Karina", 23, 11000], ["Vladimir", 21, 12000] ];
Не так давно изучаю JS просто)
0
126 / 113 / 56
Регистрация: 05.12.2012
Сообщений: 463
09.07.2015, 12:46
Сам в JS не силен, но у Вас что-то не так, на мой взгляд))
Должно быть, по идее, так:
JavaScript
1
2
3
4
5
6
7
8
var WorkerArray = new Array(
    new Worker("Mihail", 23, 10000),
    new Worker("Artem", 22, 12000),
    new Worker("Anna", 22, 14000),
    new Worker("Pavel", 24, 15000),
    new Worker("Karina", 23, 11000),
    new Worker("Vladimir", 21, 12000)
);
или так (но во втором варианте не уверен) ):
JavaScript
1
2
3
4
5
6
7
8
var WorkerArray = [
    new Worker("Mihail", 23, 10000),
    new Worker("Artem", 22, 12000),
    new Worker("Anna", 22, 14000),
    new Worker("Pavel", 24, 15000),
    new Worker("Karina", 23, 11000),
    new Worker("Vladimir", 21, 12000)
];
1
 Аватар для Liori
4 / 4 / 5
Регистрация: 30.08.2012
Сообщений: 155
09.07.2015, 12:51  [ТС]
kushok, так как я объявила массив, тоже работало, но ваш код всё-таки гораздо лучше смотрится) Спасибо
0
Модератор
 Аватар для Thisman
771 / 352 / 142
Регистрация: 17.07.2013
Сообщений: 992
09.07.2015, 15:50
Liori, если используете функцию-конструктор, то не плохо было бы просто объявить массив всех экземпляров, и через метод выводит нужное свойство
Пример

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
function Worker(name, age, payment)
{
    this.name=name;
    this.age=age;
    this.payment=payment;
    Worker.children.push(this); // добавляем в массив новый экземпляр
}
Worker.children = []; // здесь будут храниться ссылки на все экземпляры этого класса
Worker.showChildPropertys = function () {
    var children = this.children;
    for(var i in children) {
        var child = children[i];
        var pre = document.createElement("pre"); // создаем новый элемент, куда запишем данные
        for(var j in child) {
          pre.innerHTML += child[j] + " / ";
        }
        document.body.appendChild(pre);
    }
};
 
var work1 = new Worker("Mihail", 23, 10000);
var work2 = new Worker("Artem", 22, 12000);
var work3 = new Worker("Anna", 22, 14000);
var work4 = new Worker("Pavel", 24, 15000);
var work5 = new Worker("Karina", 23, 11000);
var work6 = new Worker("Vladimir", 21, 12000);
 
Worker.showChildPropertys(); // вызываем
0
88 / 88 / 34
Регистрация: 22.05.2012
Сообщений: 404
09.07.2015, 17:32
Я от чесн говоря вообще не могу догнать, а зачем ???
Можно жеж просто
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
var Worker = {
    workers: {},
 
    setWorker: function(id , name , age){
        this.workers[id] = { name: name , age: age };
    },
 
    getWorker: function(id){
        for(var i in this.workers){
            if(this.workers.hasOwnProperty(id)){
                return this.workers[id];
            }
        }
    },
 
    getWorkers: function(){
        return this.workers;
    },
 
    addRandomWorkers: function(){
        for(var i = 0; i < 10; i++){
            this.setWorker( i , 'test_' + i , Math.floor(Math.random() * 25) + 1);
        }
    },
 
    displayWorkersAll: function(){
        var pre  = document.createElement('pre');
        console.log(this.workers);
        for(var i in this.workers){
            if(this.workers.hasOwnProperty(i)){
                pre.innerHTML +=  "name -> "+ this.workers[i].name + "  age -> "+ this.workers[i].age + "\n";
            }
        }
         document.body.appendChild(pre);
    }
 
}
 
 
window.addEventListener("load", function(){
    var _this = Worker;
    
    _this.addRandomWorkers();
 
    _this.displayWorkersAll();
    
},false);
так )
0
16 / 16 / 6
Регистрация: 02.06.2015
Сообщений: 90
09.07.2015, 17:53
Вариант как у автора, но без лишних циклов:
JavaScript
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
function Worker(name, age, payment)
{
    this.name=name;
    this.age=age;
    this.payment=payment;
}
     var amount = 6;
     var work = new Array;         
 
work[1] = new Worker("Mihail", 23, 10000);
work[2] = new Worker("Artem", 22, 12000);
work[3] = new Worker("Anna", 22, 14000);
work[4] = new Worker("Pavel", 24, 15000);
work[5] = new Worker("Karina", 23, 11000);
work[6] = new Worker("Vladimir", 21, 12000);
            
document.write("<br /><strong>There are "+amount+" workers:</strong> <br /><br />");
              
     for(i=1;i<=amount;i++){
         for(var j in work[1]){
    document.write(work[i][j] + " ");}
document.write("<br /><br />");   
     }
0
88 / 88 / 34
Регистрация: 22.05.2012
Сообщений: 404
09.07.2015, 17:54
Так кажись даже веселее будет
JavaScript
1
2
3
4
5
6
7
window.addEventListener("load", function(){
     this['Worker'] = Worker;
 
        this.Worker.addRandomWorkers();
        this.Worker.displayWorkersAll();
 
},false);
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
09.07.2015, 17:54
Помогаю со студенческими работами здесь

Сократить код раскрывающихся списков
Задача такая. Сделать список типа &quot;Проводник Windows&quot; средством onClick. Данный код работает но не устраивает JS скрипт, в который нужно...

Нужно упростить/сократить код функции
&lt;html&gt;&lt;head&gt;&lt;/head&gt;&lt;body&gt; &lt;script type=&quot;text/javascript&quot;&gt; //функция, принимающая текст и создающая по нему объекты, возвращает...

Необходимо сократить код не изменяя HTML
Нужно сильно сократить код, но чтобы функционал не изменился! Прошу помочь! Спасибо. var values = { select_1: { ...

Как можно сократить код и расположить данные элементы в один целый массив?
Здравствуйте! Нужна помощь, имеется три переменных в которых расположение координаты то есть, function myFunction() { var...

Как сократить код?
На странице к ссылкам в меню прикручены якоря: &lt;aside class=&quot;left-content&quot;&gt; &lt;div class=&quot;nav&quot;&gt; &lt;ul&gt; &lt;li&gt;&lt;a...


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

Или воспользуйтесь поиском по форуму:
11
Ответ Создать тему
Новые блоги и статьи
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Access
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru