如何在 jquery 中只显示一个指定的 div


当我

单击带有 .showFormButton 类的按钮时,我试图显示一个指定的div,但不幸的是,每个带有类 .showForm 的div 都出现了。如何使用jQuery只显示一个.showFormdiv?JQUERY:

$(document).ready(function() {
$(".showFormButton").click(function(e){
e.preventDefault();
$(".showForm").css('display', 'block');
$(".showForm").css('position', 'absolute');
});
});

.HTML

print "<input type='submit' class='showFormButton' VALUE='Ulubiony' onclick='ShowDiv()'>";
    print "<div style='display: none; margin-left: -170px; margin-top: -60px; background-image: linear-gradient(rgb(15, 159, 220),rgb(14, 108, 148));' class='showForm'>";
        print "<div >";
            print "<p><b>Dodaj do ulubionych pracownika</b></br> [".$row['imie1']. " ".$row['nazwisko1']."]</p>";
            print "<p>Osobista notatka</p>";
            print "<FORM ACTION='view_tm.php' METHOD='POST' ENCRYPT='multipart/form-data' name='ulubiony_pracownik_dodaj'>";
            print "<textarea name='id_pracownik_op_notatka' rows='10' cols='45'>". $row['notatka'] ."</textarea>";
            print "<input type='hidden' name='id_pracownik_op' value='" . $row['id_pracownik'] . "'>";
            print "<INPUT TYPE='submit' id='showFormButton' NAME='ulubiony_pracownik' VALUE='Dodaj do ulubionych'>";
            print "</form>";
        print "</div>";

您必须使用this对象将所选内容定位到单击的元素上,

$(document).ready(function() {
   $(".showFormButton").click(function(e){
     e.preventDefault();
     var elm = $(".showForm", this)
     elm.css({'display' : 'block', 'position' : 'absolute' });
   });
});

您可以使用 .addClass() 来设置属性,而不是使用 .css() 来设置属性。因为它很容易维护,就像将来删除添加的属性一样。

$(document).ready(function() {
   $(".showFormButton").click(function(e){
     e.preventDefault();
     var elm = $(".showForm", this)
     elm.addClass("clicked");
   });
});

.CSS:

.clicked { display:block; position:absolute; }

编辑:

由于目标元素是当前元素的下一个同级元素,因此必须在此上下文中使用.next(selector)

$(document).ready(function() {
   $(".showFormButton").click(function(e){
     e.preventDefault();
     var elm = $(this).next(".showForm")
     elm.css({'display' : 'block', 'position' : 'absolute' });
   });
});

jQuery具有.show()函数,可以使隐藏的内容可见。看看这个代码片段:

$(document).ready(function () {
    $(document).on('click', '.action-btn', function () {
        $('.hidden-div').show();
    });
));
<div style="display: none;" class="hidden-div">
    Hidden text
</div>
<button class="action-btn">Show hidden div</button>

您可以使用属性来区分div

$(document).ready(function() {
$(".showFormButton").click(function(e){
e.preventDefault();
$(".showForm[showme='1']").css('display', 'block');
$(".showForm[showme='1']").css('position', 'absolute');
});
});

.HTML

print "<input type='submit' class='showFormButton' VALUE='Ulubiony' onclick='ShowDiv()'>";
    print "<div showme='1' style='display: none; margin-left: -170px; margin-top: -60px; background-image: linear-gradient(rgb(15, 159, 220),rgb(14, 108, 148));' class='showForm'>";
        print "<div >";
            print "<p><b>Dodaj do ulubionych pracownika</b></br> [".$row['imie1']. " ".$row['nazwisko1']."]</p>";
            print "<p>Osobista notatka</p>";
            print "<FORM ACTION='view_tm.php' METHOD='POST' ENCRYPT='multipart/form-data' name='ulubiony_pracownik_dodaj'>";
            print "<textarea name='id_pracownik_op_notatka' rows='10' cols='45'>". $row['notatka'] ."</textarea>";
            print "<input type='hidden' name='id_pracownik_op' value='" . $row['id_pracownik'] . "'>";
            print "<INPUT TYPE='submit' id='showFormButton' NAME='ulubiony_pracownik' VALUE='Dodaj do ulubionych'>";
            print "</form>";
        print "</div>";

相关内容

  • 没有找到相关文章