ASP.NET onClientClick возвращает false, не работает - PullRequest
0 голосов
/ 28 апреля 2019

Я хочу скрыть элементы div при нажатии кнопки и показать их при нажатии другой кнопки. К сожалению, при нажатии кнопки изображения всегда есть постбэк. Что вызывает эту проблему?

Вот мой код бэкэнда

protected void Page_Load(object sender, EventArgs e)
{
    for (int i = 0; i <= 10; i++)
    {
        HtmlGenericControl divTest = new HtmlGenericControl("div");
        divTest.Attributes.Add("class", "divClass");
        divTest.Attributes.Add("ID", "myDIV");
        divTest.InnerText = "Div" + i;
        form1.Controls.Add(divTest);

        ImageButton collapseButton = new ImageButton();
        collapseButton.ImageUrl = "~/images/minus.png";
        collapseButton.Attributes.Add("OnClientClick", "myHideFunction(); return false;");
        collapseButton.Height = 20;
        collapseButton.Width = 20;
        divTest.Controls.Add(collapseButton);

        ImageButton expandButton = new ImageButton();
        expandButton.ImageUrl = "~/images/plus.png";
        collapseButton.Attributes.Add("OnClientClick", "myShowFunction(); return false;");
        expandButton.Height = 20;
        expandButton.Width = 20;
        form1.Controls.Add(expandButton);
    }
}

А вот мой код переднего конца

CSS

<style>
#myDIV {
  width: 100%;
  padding: 50px 0;
  text-align: center;
  background-color: lightblue;
  margin-top: 20px;
}
</style>

Javascript

<script>

function myShowFunction() {
    var x = document.getElementById("myDIV");
    x.style.display = "block";
}

function myHideFunction() {
    var x = document.getElementById("myDIV");
    x.style.display = "none";
}
</script>

1 Ответ

1 голос
/ 28 апреля 2019

Добавить onclientclick на кнопку:

collapseButton.OnClientClick = "return myHideFunction();");

Вам нужно вернуть false из ваших методов, таких как:

<script>

function myShowFunction() {
    var x = document.getElementById("myDIV");
    x.style.display = "block";
    return false;
}

function myHideFunction() {
    var x = document.getElementById("myDIV");
    x.style.display = "none";
    return false;
}
</script>
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...