Форум программистов, компьютерный форум, киберфорум
JavaScript
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.57/7: Рейтинг темы: голосов - 7, средняя оценка - 4.57
3 / 3 / 2
Регистрация: 16.01.2014
Сообщений: 125

Target работает не так как нужно

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

Студворк — интернет-сервис помощи студентам
HTML5
1
2
3
4
5
6
7
<div>
   <div class="main">
      <div><img></div>
      <div><img></div>
      <div><img></div>
   </div>
</div>
Вот такая структура html. В блоке "main" находятся блоки с картинками внутри. Картинка на весь блок растягивается.

Функция вызывается по клику на блок main
JavaScript
1
main.onclick = function (e){}
. И по идее target должен попадать на блок и определять порядок этого элемента. Но таргет попадает на img. Что делать? Как сделать нечто похожее на z-index в css, но только для js. Чтобы при нажатии, он миновал картинку и попадал на дочерний div.

Добавлено через 14 минут
p.s. Конечно же без jquery, на чистом js

Добавлено через 15 минут
JavaScript
1
2
3
4
5
6
7
8
9
10
11
    var parent = document.getElementsByClassName("main")[0];
    
    parent.onclick = function (e){
                
                var e = e || event;
        var target = e.target || e.srcElement;
                alert(target);
        for(var i = 0; i < parent.children.length; i++) {
            if(parent.children[i] == target) return console.log(i);
        }
  }
0
Лучшие ответы (1)
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
03.08.2015, 10:12
Ответы с готовыми решениями:

setprecision() не работает, или работает не так как нужно
cout &lt;&lt; setw(5) &lt;&lt; &quot;X=&quot; &lt;&lt; setprecision(2) &lt;&lt; X; cout &lt;&lt; setw(20) &lt;&lt; &quot;X=&quot; &lt;&lt; setprecision(0)&lt;&lt; X &lt;&lt; endl; cout &lt;&lt; setw(5) &lt;&lt; &quot;Y=&quot; &lt;&lt;...

Функция не работает так, как нужно
Вот задание: В заданном одномерном массиве поменять местами соседние элементы, стоящие на чётных местах, с элементами, стоящими на...

Скидка не работает так как нужно
Написал простейший код для скидки, то есть если сумма равно только то, то скидка составляет столько то процентов. В общем если у меня...

14
Ренегат
Эксперт HTML/CSS
 Аватар для BANO
1740 / 1085 / 386
Регистрация: 06.08.2014
Сообщений: 5,203
Записей в блоге: 1
03.08.2015, 10:41
есть метод поэлегантнее
JavaScript
1
2
3
target=e.target
while (target!=parent&&target=target.parent&&target!=document){}
if(target==document)return true
0
3 / 3 / 2
Регистрация: 16.01.2014
Сообщений: 125
03.08.2015, 10:44  [ТС]
Цитата Сообщение от BANO Посмотреть сообщение
target=e.target
while (target!=parent&&target=target.parent&&t arget!=document){}
if(target==document)return true
Хммм..
Цитата Сообщение от fajjet Посмотреть сообщение
И по идее target должен попадать на блок и определять порядок этого элемента
0
Ренегат
Эксперт HTML/CSS
 Аватар для BANO
1740 / 1085 / 386
Регистрация: 06.08.2014
Сообщений: 5,203
Записей в блоге: 1
03.08.2015, 10:49
Лучший ответ Сообщение было отмечено fajjet как решение

Решение

target это элемент на который попал евент
а вот this в твоём коже будет именно <div class="main">

Добавлено через 1 минуту
вот урок
1
3 / 3 / 2
Регистрация: 16.01.2014
Сообщений: 125
03.08.2015, 11:06  [ТС]
Спасибо)) Еще один вопрос. Допустим в этот div вложен p. Как обратиться к нему, чтобы узнать его высоту, например.
JavaScript
1
2
3
4
5
6
7
8
9
10
               var elems = document.querySelectorAll('.in-top');
 
    for (var i = 0; i < elems.length; i++) {
        elems[i].addEventListener("click", nsize, true);
    }
                function nsize(){
 
        this.style.width = '10%';
 
    }
Вот в этой же функции
0
Ренегат
Эксперт HTML/CSS
 Аватар для BANO
1740 / 1085 / 386
Регистрация: 06.08.2014
Сообщений: 5,203
Записей в блоге: 1
03.08.2015, 11:13
Цитата Сообщение от fajjet Посмотреть сообщение
for (var i = 0; i < elems.length; i++) {
* * * * elems[i].addEventListener("click", nsize, true);
* * }
не самый лучший способ


ну а высоту и ширину можно узнать либо через getComputedStyle либо, что менее заморочено, через innerHeight, а ширину через innerWidth
0
3 / 3 / 2
Регистрация: 16.01.2014
Сообщений: 125
03.08.2015, 11:29  [ТС]
Мне на самом деле не надо узнавать ширину. Просто проверял. Вот настоящая задача.
HTML5
1
2
3
4
5
<div class="main">
   <div><img><p></p></div>
   <div><img><p></p></div>
   <div><img><p></p></div>
</div>
Нажимая на блок, нужно обратиться к в дочернему элементу p, узнать его высоту и транслейтом сместить блок, на который нажали на высоту p.

Добавлено через 45 секунд
Как такое реализовать?))
0
Ренегат
Эксперт HTML/CSS
 Аватар для BANO
1740 / 1085 / 386
Регистрация: 06.08.2014
Сообщений: 5,203
Записей в блоге: 1
03.08.2015, 11:42

Не по теме:

ну ты и...



ладно не важно, в настоящей задаче не понятно какой p, какой блок, распиши пожалуйста попонятнее
0
3 / 3 / 2
Регистрация: 16.01.2014
Сообщений: 125
03.08.2015, 11:49  [ТС]
Цитата Сообщение от fajjet Посмотреть сообщение
<div class="main">
* *<div><img><p></p></div>
* *<div><img><p></p></div>
* *<div><img><p></p></div>
</div>
Общий блок main. В котором находятся divы, c шириной 20%. Вот при нажатии на эти divы, нужно обращаться к p элементу и определять его высоту. Высоты у p как таковой нет. Только паддинги. То есть это будет делаться через clientHeight. Самое главное это узнать высоту p, и сместить этот родительский div, на который нажали транслейтом на эту же высоту. Надеюсь понятно))
0
Ренегат
Эксперт HTML/CSS
 Аватар для BANO
1740 / 1085 / 386
Регистрация: 06.08.2014
Сообщений: 5,203
Записей в блоге: 1
03.08.2015, 11:53
fajjet, честно не очень
особенно слово транслейтом
0
3 / 3 / 2
Регистрация: 16.01.2014
Сообщений: 125
03.08.2015, 12:00  [ТС]
HTML5
1
2
3
4
5
<div class="main">
  <div class="child"><img><p></p></div>
  <div class="child"><img><p></p></div>
  <div class="child"><img><p></p></div>
</div>
В общем про анимацию забей)) Есть блок "main". Ширина и высота 100%. В нем блоки "child" с шириной 20% и высотой 100%. В блоке "child" вложен IMG и P. Вот при нажатии на блок child, нужно получить высоту дочернего элемента P.
0
Ренегат
Эксперт HTML/CSS
 Аватар для BANO
1740 / 1085 / 386
Регистрация: 06.08.2014
Сообщений: 5,203
Записей в блоге: 1
03.08.2015, 12:40
а если клик будет мимо child?

ну ладно это не важно, сейчас сделаю
0
3 / 3 / 2
Регистрация: 16.01.2014
Сообщений: 125
03.08.2015, 12:41  [ТС]
Да не)) Все я сам методом тыка разобрался)) Спасибо за помощь.
JavaScript
1
2
3
4
5
6
7
8
9
var elems = document.querySelectorAll('.specification > div');
 
    for (var i = 0; i < elems.length; i++) {
        elems[i].addEventListener("click", highlightThis, true);
    }
 
    function highlightThis() {
        this.querySelector("p").style.background = "black";
    }
Просто JS синтаксис плохо знаю((
0
Ренегат
Эксперт HTML/CSS
 Аватар для BANO
1740 / 1085 / 386
Регистрация: 06.08.2014
Сообщений: 5,203
Записей в блоге: 1
03.08.2015, 13:01
ну я старался)))
вот то чо получилось
JavaScript
1
2
3
4
5
6
7
    main=document.getElementsByClassName("main")[0];
    main.onclick=function(e){
        targ= e.target || e.srcElement;
        if(targ==this) return true/*юзер промазал по чилдам*/
        while(!targ.parentNode.classList.contains("main")&&(targ=targ.parentNode)){        }
        alert(targ.querySelector("p").clientHeight)
    }


Добавлено через 2 минуты
а твой код можно и покороче записать

JavaScript
1
2
3
4
5
6
[].forEach.call(document.querySelectorAll('.specification > div'),function(e){
   e.addEventListner("click",highlightThis,false)// тут я немного отсебятины поставил, а точнее false
})
    function highlightThis() {
        this.querySelector("p").style.background = "black";
    }
единственное, я не понимаю зачем тебе true?
1
3 / 3 / 2
Регистрация: 16.01.2014
Сообщений: 125
03.08.2015, 13:08  [ТС]
Спасибо за старание, но мне подходит второй вариант больше. Так как будет имитация hover. То есть два ивентлистенера. Тру стояло по дефолту)) Я даже не знаю синтаксис этой функции))) Сейчас прочитал синтаксис - убрал))) Еще раз спасибо за помощь и старания)))
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
03.08.2015, 13:08
Помогаю со студенческими работами здесь

Скрипт работает не так, как нужно
Мой html: &lt;form method=&quot;post&quot; name=&quot;calcForm&quot; id=&quot;calcForm&quot; action=&quot;&quot;&gt; &lt;fieldset&gt; &lt;input type=&quot;checkbox&quot;...

Слип работает не так как нужно
В чем проблема, когда слип отрабатывает кнопка висит в состоянии нажатия а не после того как все изменения прошли. Я видимо не знаю как...

rand() работает не так как нужно
Запускается n потоковых функций, каждый из них приостанавливается во время своего выполнения, а в главное программе должен перезапускаться....

NetworkStream.DataAvailable работает не так как нужно!
try { byte bytes = new byte; int i = 0; do { ...

Событие Shown работает не так как нужно
Повесил событие private void Form1_Shown(object sender, EventArgs e) Но оно работает не так как нужно. Суть заключается в том что когда...


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

Или воспользуйтесь поиском по форуму:
15
Ответ Создать тему
Новые блоги и статьи
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост. Налог на собак: https:/ / **********/ gallery/ V06K53e Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf Пост отсюда. . .
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод. Thinkpad X220 Tablet —. . .
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
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru