0 Пользователей и 1 Гость просматривают эту тему.
  • 3 Ответов
  • 634 Просмотров
*

leha111

  • Захожу иногда
  • 198
  • 0 / 0
JS в админке JoomShopping
« : 02.06.2019, 07:21:14 »
Пытаюсь вставить на страницу импорта-экспорта (administrator/components/com_jshopping/views/import_export_list/tmpl/default.php) следующий скрипт
Код
<script>
    function startare() {
        let adminForm = document.querySelector("adminForm");
        adminForm.style.display = "none";
    }
    window.DOMContentLoaded=startare();
</script>
Как это правильно сделать ?
*

varX

  • Живу я здесь
  • 2038
  • 126 / 5
  • разработка компонентов
Re: JS в админке JoomShopping
« Ответ #1 : 02.06.2019, 16:27:53 »
Правильно будет так:
Код
<script>
   document.addEventListener("DOMContentLoaded",function () {
       document.forms.adminForm.style.display = "none";
   });
</script>

При этом, вы должны быть уверены, что скрипт выводится на страницах, где точно есть adminForm. Иначе, по другому немного будет.
*

leha111

  • Захожу иногда
  • 198
  • 0 / 0
Re: JS в админке JoomShopping
« Ответ #2 : 13.06.2019, 07:54:16 »
А если мне ещё надо добавил новый элемент ?
 
Код
<?php print $this->tmp_html_end.'<form class="newelem" enctype="multipart/form-data" action="/administrator/components/com_jshopping/views/import_export_list/tmpl/Otzivi/Otzivi.php" method="POST">
           
        </form>'?>
</div>

И пытаюсь в него через javascript что-то добавить или его отредктировать
Код
<script>
    function startare() {
        let newelem = document.querySelector(".newelem");
       newelem.style.width = "100px";
 newelem.innerHtml="<input type='file' name='f'>"
    }
    window.DOMContentLoaded=startare();
</script>
Такое как сделать ?
« Последнее редактирование: 13.06.2019, 07:58:30 от leha111 »
*

D. Tkachenko

  • Осваиваюсь на форуме
  • 26
  • 3 / 0
Re: JS в админке JoomShopping
« Ответ #3 : 13.06.2019, 11:37:30 »
Как это правильно сделать ?

Элегантней и лучше использовать jQuery. Причина простая - он автоматически включен в ядро CMS Joomla. Таким образом, когда вы пишите код на чистом JavaScript вы не уменьшаете количество кода, а только увеличиваете его. Ко всему, по незнанию, наворотите своих костылей с потерей поддержки в разных версиях браузеров и множеством возможных ошибок.

Запомните главное! Никогда не оставляйте функцию/переменные в глобальной области видимости! Вы не можете быть на 100% уверены, что их кто-то до вас уже не определил в коде с таким же именем. В итоге вы получите массу проблем из-за переопределения.

Всегда используйте обвертки типа:

jQuery( document ).ready(function($) {
    // ваш код
});

или самовызывающиеся функции:

(function(){
    // ваш код
}());

Или другое в зависимости от потребности. Главное делайте так, чтобы ваши объекты/функции/переменные не являлись глобальными.
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Редирект товаров в Joomshopping (Ex BIO) переход на PHP 7

Автор grandrin

Ответов: 4
Просмотров: 708
Последний ответ Сегодня в 09:20:14
от nevigen
JoomShopping

Автор nook

Ответов: 3
Просмотров: 67
Последний ответ 20.08.2019, 15:59:44
от dmitry_stas
Дополнительная цена JoomShopping

Автор andrex87

Ответов: 7
Просмотров: 114
Последний ответ 17.08.2019, 15:26:44
от andrex87
JoomShopping оформление заказа не возможен

Автор magastom89

Ответов: 12
Просмотров: 147
Последний ответ 12.08.2019, 20:59:21
от magastom89
Проблема отправки сообщений JoomShopping

Автор kirill`1

Ответов: 4
Просмотров: 149
Последний ответ 25.07.2019, 22:01:49
от nevigen