2 / 2 / 0
Регистрация: 23.10.2008
Сообщений: 25

код в HTML работает, но не работает в JavaScript

06.04.2011, 19:20. Показов 3575. Ответов 2
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Вот куски кода...
HTML5
1
2
3
4
5
6
<input type="checkbox" name="installation_n" onclick="nast()"/>Наш монтаж<br>
 <table id="equip">
 </table> 
 <script type="text/javascript" src="file:///G:/Insyte5/commerc.js"></script> 
 <input type="button" name="comerc_n" id="comerc_id" value="Сформировать коммерческое предложение" onclick="commerc()"/> 
 <script type="text/javascript" src="file:///G:/Insyte5/table.js"></script>
скрипт commerc.js
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
     function t_equipment(name, type_s)
     {
      this.type_s = type_s;
      this.name = name;
     }
     
     var a_equipment = new Array();
     a_equipment[0] = new t_equipment("Логический контроллер", "logic_controllers")
     a_equipment[1] = new t_equipment("Встраиваемые микромодули", "embeddable_micromodules")
     
     function equipment(name, price, count, vsego, description, t_equipment, id)
     {
      this.name = name;   
      this.price = price;
      this.count = count; 
      this.vsego = vsego; 
      this.description = description;
      this.t_equipment = t_equipment;
      this.id = id;   
     }   
     //equipment.id = document.getElementById("equip");
     
     var n_equipment = new Array();  
     n_equipment[0] = new equipment("SPIDER2", 500, "", "", "Программируемый логический контроллер, USB, Ethernet, RS-485, RS-232, 1-Wire, 4 реле, 4 дискр. входа, 2 аналог. входа, GSM-модем, GSM-антенна, USB-кабель, DIN", a_equipment[0])
     n_equipment[1] = new equipment("SPIDER", 250, "", "", "Программируемый логический контроллер, RS-485, RS-232, блок питания, кабель, DIN", a_equipment[0])
 
 function n_montaj(names, price, vsego)
 {
  this.names = names;
  this.price = price;
 } 
 var montaj = new Array();
 montaj[0] = new n_montaj();
 montaj[1] = new n_montaj("Работы по монтажу системы", 100);
скрипт table.js
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
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
function commerc()
 {
     var vss = 0;
     var pusk = 0;   
     comm = window.open("", "Автоматизация",     "width = 1200px, height = 1600px, status=yes, toolbar=yes, menubar=yes", true);
     comm.document.open();      
     comm.document.write("<h2 align='center'> Коммерческое предложение </h2>");
 
     var strTab = "<table border='2' ><tr>"
     strTab += "<th> Тип </th><th width=100px> Наименование </th><th width=80px> Цена </th><th width=65px> Кол-во </th><th width=100px >"
     strTab += "Всего </th><th width=550px > Описание </th>"    
     for(var i = 0; i <= n_equipment.length - 1; i ++) 
     {
      vss = parseFloat(1 * (n_equipment[i].price));
      strTab += "<TR><TD>" + n_equipment[i].t_equipment.name + "</TD><TD align=left >" + n_equipment[i].name 
      strTab += "</TD><TD align=center >" + n_equipment[i].price + "</TD><TD align=center >" + 1/*n_equipment[i].count*/ 
      strTab += "</TD><TD align=center >" + vss/*n_equipment[i].vsego*/ + "</TD><TD><h5>" + n_equipment[i].description + "</h5></TD></TR>"  
     } 
     strTab += "</table>"  
     comm.document.write(strTab);   
    //******************************************************************
    // Подсчёт количества элементов
     var col = 0;    
     var count_col = new Array();
     for( var i = 1; i < document.getElementById("equip").rows.length; i ++)
     {
      count_col = parseInt(document.getElementById("equip").rows[i].cells[3].innerHTML);
      col += count_col;  
     }   
     strTab = "<table border='2' ><tr>"  
     strTab += "<tr><td align='right' width='495px' >Кол-во: " + col + "</td></tr>"
     strTab += "</table>"  
     comm.document.write(strTab);     
    //****************************************************************** 
    // Подсчёт итоговой суммы     
     var vs = 0;
     var count_vs = new Array();
     for( var i = 1; i < document.getElementById("equip").rows.length; i ++)
     {
      count_vs = parseFloat(document.getElementById("equip").rows[i].cells[2].innerHTML);
      vs += count_vs;
      //alert(vs);  
     }   
     strTab = "<table border='2' ><tr>"
     strTab += "<tr><td align='right' width='600px' > Итого стоимость оборудования: " + vs + " руб.</td></tr>"
     strTab += "</table>" 
     comm.document.write(strTab);    
    //******************************************************************
    // Виды работ   
     strTab = "<table 'border='2' ><tr>"
     strTab += "<th align='center' width=40px > №: </th><th align='left' width=600px > Наименование работ "
     strTab += "</th><th align='center' width=90px > Кол-во (шт.) </th><th align='center' width=80px > Цена (руб.) "
     strTab += "</th><th align='center' width=100px > Сумма (руб.) </th>"    
     var mvs = 0;
     for(var i = 1; i <= montaj.length - 1; i ++) 
     {
      mvs = parseFloat(col * (montaj[i].price));
      strTab += "<TR><TD align=center>" + i + "</TD><TD align=left>" + montaj[i].names + "</TD><TD align=center>" + col  
      strTab += "</TD><TD align=right>" + montaj[i].price + "</TD><TD>" + mvs + "</TD></TR>"       
     }   
     strTab += "</table>" 
     comm.document.write(strTab);    
    //******************************************************************
    // Расчёт суммы пусконаладочных работ
     strTab = "<table border='2'> <tr>"
     strTab += "<tr><td align='left' width='645px'> Пуск и наладка составляет 15% от стоимости оборудования и монтажных работ: </td><td>" 
     strTab += + pusk + " руб.</td></tr>" 
     strTab += "</table>"
     comm.document.write(strTab); 
     comm.document.close();  
 }
Если код вставить в HTML файл между тегами <javascript> </javascript> работает, но если код находится в js файле то код не работает. Ошибка в файле table.js в строке 30
текст ошибки в мозиле document.getElementById("equip") is null
а гугле Uncaught TypeError: Cannot read property 'rows' of null
в опере ошика в строке 30
Uncaught exception: TypeError: Cannot convert 'document.getElementById("equip")' to object.

На другом форуме мне советовали сначала сгенерировать таблицу, затем уже перебирать элементы таблицы и уже после этого загружать данные на сайт. Но всё равно ничего не получается. Помогите.
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
06.04.2011, 19:20
Ответы с готовыми решениями:

Не работает PHP код. Файлы .php не обрабатываются, хотя, если занести в html, всё работает.
не могу разобраться с проблемой. установила денвер, вроде все работает, но как только начала заниматься выяснилось что файлы php не...

Не работает html вместе с javascript
Возникла у меня проблема: при нажатии на ссылку &quot;В начало&quot; курсор на странице должен переходить туда, где находится якорь name. Но ссылка...

Не работает код JavaScript
Добрый день! Помогите, пожалуйста, решить проблему. Все работало много лет, но тут почему-то перестал работать код &lt;script&gt; ...

2
221 / 135 / 48
Регистрация: 12.04.2010
Сообщений: 248
06.04.2011, 21:09
Во первых: в IE, Chrome, Opera, FF у меня все работает, табличка генерируется, выводится и ошибок нет.
Во вторых: зачем тебе перебирать элементы таблицы, если у тебя все необходимые данные есть в объектах. (да и зачем эти объекты? можно с тем же успехом заменить просто массивами)
В третьих: зачем полный путь к скриптам? (file:///G:/Insyte5/)
0
2 / 2 / 0
Регистрация: 23.10.2008
Сообщений: 25
06.04.2011, 21:50  [ТС]
Если у Вас работает, то это говорит о том что у меня руки кривые.
Но у меня таблица тоже генерировалась, только вот не считалось количество и сумма. Перебор элементов я стал делать для того чтобы понять как считать количество и сумму. Зачем полный путь к скриптам, так это потому что я скрипты тестирую локально, а уже после тестирования заливаю на свой сайт.

Добавлено через 24 минуты
на хостинге где у меня сайт, там не разрешено пользоваться php скриптами, и там нет sql сервера. А мне нужно было на сайте сделать on-line калькулятор, я его сделал при помощи скриптов, получилось каряво, но работает. Теперь вот понадобилось формировать ком.предложения, на основании тех данных что выбраны в on-line калькуляторе . Я решил это сделать таким макаром - создать массив с данными, к которому обращается калькулятор, и далее формировать ком.предложения. Может есть путь легче, подскажите.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
06.04.2011, 21:50
Помогаю со студенческими работами здесь

Не работает код на JavaScript
Пытаюсь изучать Java Script, но почти все учебники требуют знания основ html. Разметку я подучил, но оказывается надо еще знать телепатию,...

Почему не работает код JavaScript?
Здравствуйте! Скажите пожалуйста, почему не работает код JavaScript (должен в конце показывать произведение элементов массива, а...

Не работает написанный JavaScript код в Google Chrome
JavaScript код не работает в Google Chrome, а во всех остальных браузерах все нормально работает. Как сделать так, чтобы работало во всех...

Начал изучать Javascript, не работает код в консоле
Первое выражение я скопировал из файла, второе написал(переписал, для теста) сам. Почему оно не работает?

Не работает код внутри html
Как понятно из названия, не работает код. Причина мне не известна, но скорее всего дело в моих прямых руках. Вот сам исходник: ...


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Опции темы

Новые блоги и статьи
SDL3 для Web (WebAssembly): Обработчик клика мыши в браузере ПК и касания экрана в браузере на мобильном устройстве
8Observer8 02.02.2026
Содержание блога Для начала пошагово создадим рабочий пример для подготовки к экспериментам в браузере ПК и в браузере мобильного устройства. Потом напишем обработчик клика мыши и обработчик. . .
Философия технологии
iceja 01.02.2026
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
SDL3 для Web (WebAssembly): Вывод текста со шрифтом TTF с помощью SDL3_ttf
8Observer8 01.02.2026
Содержание блога В этой пошаговой инструкции создадим с нуля веб-приложение, которое выводит текст в окне браузера. Запустим на Android на локальном сервере. Загрузим Release на бесплатный. . .
SDL3 для Web (WebAssembly): Сборка C/C++ проекта из консоли
8Observer8 31.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
SDL3 для Web (WebAssembly): Установка Emscripten SDK (emsdk) и CMake для сборки C и C++ приложений в Wasm
8Observer8 30.01.2026
Содержание блога Для того чтобы скачать Emscripten SDK (emsdk) необходимо сначало скачать и уставить Git: Install for Windows. Следуйте стандартной процедуре установки Git через установщик. . . .
SDL3 для Android: Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 30.01.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами. Версия v3 была полностью переписана на Си, в. . .
Инструменты COM: Сохранение данный из VARIANT в файл и загрузка из файла в VARIANT
bedvit 28.01.2026
Сохранение базовых типов COM и массивов (одномерных или двухмерных) любой вложенности (деревья) в файл, с возможностью выбора алгоритмов сжатия и шифрования. Часть библиотеки BedvitCOM Использованы. . .
SDL3 для Android: Загрузка PNG с альфа-каналом с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 28.01.2026
Содержание блога SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru