Форум: Форум PHPФорум ApacheФорум Регулярные ВыраженияФорум MySQLHTML+CSS+JavaScriptФорум FlashРазное
Новые темы: 0000000
PHP 5/6. В подлиннике. Авторы: Кузнецов М.В., Симдянов И.В. PHP Puzzles. Авторы: Кузнецов М.В., Симдянов И.В. Самоучитель MySQL 5. Авторы: Кузнецов М.В., Симдянов И.В. PHP 5. На примерах. Авторы: Кузнецов М.В., Симдянов И.В., Голышев С.В. C++. Мастер-класс в задачах и примерах. Авторы: Кузнецов М.В., Симдянов И.В.
ВСЕ НАШИ КНИГИ
Консультационный центр SoftTime

HTML+CSS+JavaScript

Выбрать другой форум

 

Здравствуйте, Посетитель!

вид форума:
Линейный форум Структурный форум

тема: дополнительные атрибуты тегов HTML
 
 автор: kirillKiev   (16.02.2009 в 14:49)   письмо автору
 
 

Вопрос
Если использовать дополнительные (свои) атрибуты в HTML тегах то несет ли это для функциональности страницы какие то потенциальные опасности кроме просто не соответствия стандартам?
например

<div newAttribute="{a:1,b:2}"></div>

Зачем нужно - что бы как то передать дополнительную информацию привязанную к html элементу с сервера в javascript

  Ответить  
 
 автор: Lelik   (16.02.2009 в 15:51)   письмо автору
 
   для: kirillKiev   (16.02.2009 в 14:49)
 

Всё нормально. Только я бы так делать не рекомендовал, лучше сделать глобальный массив с нужными данными, примерно так:

<script>
var arrData = [];
function aaa() {
alert(arrData);
}
aaa();
</script>

ЗЫ. Кстати, если уже затрагивать тему стандартов, то хочу заметить, что это всего лишь рекомендации для разработчиков браузеров, сами стандарты задают браузары, а не w3c, это следует помнить.

  Ответить  
 
 автор: KirillKiev   (16.02.2009 в 15:57)   письмо автору
 
   для: Lelik   (16.02.2009 в 15:51)
 

Спасибо за ответ.
Что бы делать глобальный массив буду вынужден цеплять уникальные id на все нужные элементы (а их может быть тысячи) что бы потом как то привязацца, а в таком варианте не нужно. Можно потом перебрать элементы например по имени класса или как то по другому и понавешивать все что нужно (например события).
И вопрос...
:)
почему все таки если "все нормально" => "делать так не рекомендовал"
ход мысли какой?

  Ответить  
 
 автор: Lelik   (16.02.2009 в 16:22)   письмо автору
 
   для: KirillKiev   (16.02.2009 в 15:57)
 

потому, что вынимаю подобную инструкцию из аттрибута:

<div newAttribute="{a:1,b:2}"></div>

придется применять eval, что работает разков в 10—100 медленней чем напрямую к массиву обращаться...

  Ответить  
 
 автор: KirillKiev   (16.02.2009 в 16:33)   письмо автору
 
   для: Lelik   (16.02.2009 в 16:22)
 

возможно.... но без eval, особенно с AJAX очень проблематично
так что от eval все равно никуда...
еще можно разобрать эту строку в массив и обойтись без eval

  Ответить  
 
 автор: Lelik   (16.02.2009 в 17:10)   письмо автору
 
   для: KirillKiev   (16.02.2009 в 16:33)
 

вот хорошая статья по теме. в смысле по теме быстродействия :)

  Ответить  
 
 автор: KirillKiev   (16.02.2009 в 17:30)   письмо автору
 
   для: Lelik   (16.02.2009 в 17:10)
 

Спасибо за ссылку
Ну... из всей статьи действительно по тему только
>>
var propertyName = "value";
eval("obj." + propertyName + "= 1")

выполняется в 10—100 раз дольше, чем

obj[propertyName] = 1
<<
это как раз понятно
остальное известно..

  Ответить  
 
 автор: sl1p   (16.02.2009 в 18:03)   письмо автору
 
   для: KirillKiev   (16.02.2009 в 16:33)
 

но без eval, особенно с AJAX очень проблематично
смотря что, если передавать массив можно просто обойтись разделителем и уже на выходе разбивать в массив.

  Ответить  
Rambler's Top100
вверх

Rambler's Top100 Яндекс.Метрика Яндекс цитирования