gpt4 book ai didi

javascript - AJAX 中的 event.target

转载 作者:行者123 更新时间:2023-11-28 04:23:02 24 4
gpt4 key购买 nike

希望我的问题不太复杂。

function showSkills(event,str) {

xmlhttp = new XMLHttpRequest();
xmlhttp.onreadystatechange = function() {
if (this.readyState == 4 && this.status == 200) {
event.target.parentElement.parentElement.parentElement.nextElementSibling.innerHTML = this.responseText;
}
};
xmlhttp.open("POST","skills.php",true);
xmlhttp.setRequestHeader("Content-type","application/x-www-form-urlencoded");
xmlhttp.send("q=" + str);
event.target.parentElement.parentElement.parentElement.nextElementSibling.style.display = "block";
}

该 block 已显示,因此最后一行代码很好,但我无法发布 $q 。我知道问题出在哪里,但不知道如何解决:如果我输入 document.getElementById("skills").innerHTML = this.responseText;而不是event.target.parentElement.parentElement.parentElement.nextElementSibling.innerHTML = this.responseText;一切正常,但仅限于 <div id="skills'> ,不适用于skills2当然。我必须使用此脚本来获取更多 div ID (skills, skills2, skills3)分别。

我的 HTML:

<div class="bgimg" style="background-image:url('pic/a3.jpeg');">
<h3 onclick="displayGrow(event)">bla bla</h3>
<div id="sport" class="hide resetInput"><?php include 'sport.php'; ?></div>
<div id="skills" class="hide resetInput"><?php include 'skills.php'; ?></div>
</div><!-- end of the 1st Parallax -->

<div class="bgimg" style="background-image: url('pic/a5.jpg');">
<h3 onclick="displayGrow(event)">bla bla</h3>
<div id="sport2" class="hide resetInput"><?php include 'sport.php'; ?></div>
<div id="skills2" class="hide resetInput"><?php include 'skills.php'; ?></div>
</div><!-- end of the 2nd Parallax -->

sport.php代码:

<?php
include 'cookies.php';
if ($_SERVER["REQUEST_METHOD"] == "POST") {
if (isset($_POST['q'])) {
$q = $_POST['q'];
}}
?>

<div class="dropdown marginTop">
<button><!-- select sport -->
<?php // "select your sport"
if (isset($q)) {
$result = mysqli_query($con, 'SELECT ' .$language. ' FROM sports WHERE name1="' .$q. '" LIMIT 1');
} else {
$result = mysqli_query($con, 'SELECT ' .$language. ' FROM page WHERE title="selSport1" LIMIT 1');
}
$row = mysqli_fetch_row($result);
print_r($row[0]);
?>
</button>
<div class="dropdown-content">
<?php // sports list
$sportlist = mysqli_query($con, 'SELECT * FROM sports WHERE title = "sports" ORDER BY ' .$language. ' ASC');
while ($row = mysqli_fetch_array($sportlist)) {
echo '
<button class = "buttonList" value="' . $row[1] . '"';?>
onclick="showSport(event, this.value); showSkills(event, this.value);"
<?php echo ' style="border:0;">' . $row[$language] . '</button>
';
}
?>
</div>
</div>

所以在showSport()之后被调用时,带有 $q 的按钮值显示在 sport.php 。这对于两个 div ID 都适用:sportsport2还有。另一个功能showSkills()应该打开skill.php<div id="skills">或在 <div id="skills2">并发布$q那里。该部分已打开,但没有 $q里面。有任何想法吗?对我有很大帮助。

最佳答案

event.target.parentElement.parentElement.parentElement.nextElementSibling 就我的口味而言,在 DOM 上攀爬的次数太多了。当我理解正确时,您将使用相同的函数作为多个元素的事件处理程序。为什么不直接将特定的关联 div 的 ID 作为参数传递呢?我在下面添加一个示例。

// Note, I do not know what your 'str' is, so here it is just 'foo'
document.getElementById('event-div-1').addEventListener('click', showSkills.bind(null, 'skills1', 'foo'));
document.getElementById('event-div-2').addEventListener('click', showSkills.bind(null, 'skills2', 'foo'));
document.getElementById('event-div-3').addEventListener('click', showSkills.bind(null, 'skills3', 'foo'));


function showSkills(skills, event, str) {
// Ajax stuff
document.getElementById(skills).style.display = 'block';
}
.skills {
display: none;
}
<div class="skills" 
id="skills1">1</div>
<div class="skills"
id="skills2">2</div>
<div class="skills"
id="skills3">3</div>

<div id="event-div-1">Click me for skills 1</div>
<div id="event-div-2">Click me for skills 2</div>
<div id="event-div-3">Click me for skills 3</div>

关于javascript - AJAX 中的 event.target,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45295524/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com