【问题标题】:Form doesn't work on server and only on mobile version表单在服务器上不起作用,只能在移动版本上使用
【发布时间】:2026-01-03 06:30:01
【问题描述】:

当我在 localhost 中时,网站和表单完美运行,但当它上传到服务器时,表单仅适用于桌面版本,在移动设备上,表单不会过滤,仅显示所有专业人员。 该网站使用引导程序和 javascript 构建。



<script type="text/javascript">
  window.onload=function(){
var element1 = document.getElementById("link-index");
element1.classList.remove("active");
     var element = document.getElementById("link-profesionales");
     element.classList.add("active");
}
</script>
<div class=" p-2" style="background-color: #f2f3f4;">
<nav class="" aria-label="breadcrumb">
  <div class=" col-sm-1 col-md-12 col-lg-12">
    <ol class="breadcrumb">
      <li class="ms-lg-5 ms-4 breadcrumb-item"><a class="breadcrumb-css" href="index.php">Inicio</a></li>
      <li class="breadcrumb-item active" aria-current="page">Profesionales</li>
    </ol>
  </div><h1 class="ms-lg-5 ms-4">Profesionales</h1>
</nav>
</div>

<style type="text/css">

/* Create three equal columns that floats next to each other */
.column {
  display: none; /* Hide columns by default */
  
}

/* Clear floats after rows */
.row:after {
  content: "";
  display: table;
  clear: both;
}

/* Content */
.content {
  background-color: white;
  
}

/* The "show" class is added to the filtered elements */
.show {
  display: block;
}

.card-footer{
position:absolute;
  bottom:0;
  width:100%;
  background-color: white;
}

.form-select:focus {
  border-color: #FFBE2C;
  outline: 0;
  box-shadow: 0 0 0 0.25rem #FFBE2C;
}
/* 
select option {
    background-color: #FFBE2C;
    font-weight: bold;
    color: white;
}

 
select option:checked{
    box-shadow: 0 0 10px 100px #1882A8;
    background-color: #FFBE2C;
    font-weight: bold;
    color: white;
}
*/
</style>

<div class="container">
    <div class="row">
<div class="mt-5 col-12 text-center">

<div class="btn-group col-auto" role="group" aria-label="Basic example">
  <form class="" method="GET" action="profesionales.php" id="formprofeesionales" >
    <label style="font-weight: bold;" for="exampleFormControlInput1" class="form-label col-md-8">Consultar por Especialidad:</label>
    <select id="select1" onchange="filterSelection('all')" class="form-select" aria-label="Default select example">
  <option selected value="all">Todos</option>
  <option onclick="filterSelection('Fisioterapia')" value="Fisioterapia">Fisioterapia</option>
  <option onclick="filterSelection('Fonoaudiología')" value="Fonoaudiología">Fonoaudiología</option>
  <option onclick="filterSelection('Psicología')" value="Psicología">Psicología</option>
</select>
</form>
</div>
</div>
</div>




<!-- Portfolio Gallery Grid -->
<div class="row row-cols-2 g-2 row-cols-md-6 mt-1">
  
  <div class="border-0 me-lg-4 my-lg-4  col card column Fonoaudiología">
    <div class="content">
      <div class="h-100 card ">
  <img src="https://www.bizkaiatalent.eus/wp-content/uploads/2014/05/ETB_Estibaliz-Ruiz-de-Azua1.jpg" class="img-thumbnail card-img-top border-0" alt="mountains">
  <div class="card-body">
    <h5 class="card-title">María Silvina Luchino</h5>
    <p class="card-text">Fonoaudiologa</p>
    <p class="mb-5 card-text">MP 34567</p>
    </div>
    <div class="card-footer"><a href="#" class="especialidades btn btn-sm">Contactar</a></div>
  
        </div>
    </div>
  </div>

  <div class="border-0 me-lg-4 my-lg-4 col card column Psicología">
      <div class="h-100 card ">
  <img src="https://www.bizkaiatalent.eus/wp-content/uploads/2014/05/ETB_Estibaliz-Ruiz-de-Azua1.jpg" class="img-thumbnail card-img-top border-0" alt="mountains">
  <div class="card-body">
    <h5 class="card-title">Milanesa Ola</h5>
    <p class="card-text">Psicología</p>
    <p class="mb-5 card-text">MP 34567</p>
    </div>
    <div class="card-footer"><a href="#" class="especialidades btn btn-sm">Contactar</a></div>
  
    </div>
    </div>

<div class="border-0 me-lg-4 my-lg-4 col card column Psicología">
    <div class="content">
      <div class="h-100 card ">
  <img src="https://www.bizkaiatalent.eus/wp-content/uploads/2014/05/ETB_Estibaliz-Ruiz-de-Azua1.jpg" class="img-thumbnail card-img-top border-0" alt="mountains">
  <div class="card-body">
    <h5 class="card-title">Carla Paguaga de Santos</h5>
    <p class="card-text">Psicología</p>
    <p class="mb-5 card-text">MP 34567</p>
    </div><div class="card-footer"><a href="#" class="especialidades btn btn-sm">Contactar</a></div>
  
        </div>
    </div>
  </div>
<div class="border-0 me-lg-4 my-lg-4 col card column Psicología">
      <div class="h-100 card ">
  <img src="https://www.bizkaiatalent.eus/wp-content/uploads/2014/05/ETB_Estibaliz-Ruiz-de-Azua1.jpg" class="img-thumbnail card-img-top border-0" alt="mountains">
  <div class="card-body">
    <h5 class="card-title">Marta</h5>
    <p class="card-text">Psicología</p>
    <p class="mb-5 card-text">MP 34567</p>
    </div><div class="card-footer"><a href="#" class="especialidades btn btn-sm">Contactar</a></div>
  
    </div>
    </div>
    <div class="border-0 me-lg-4 my-lg-4 col card column Psicología">
      <div class="h-100 card ">
  <img src="https://www.bizkaiatalent.eus/wp-content/uploads/2014/05/ETB_Estibaliz-Ruiz-de-Azua1.jpg" class="img-thumbnail card-img-top border-0" alt="mountains">
  <div class="card-body">
    <h5 class="card-title">Lucia</h5>
    <p class="card-text">Psicología</p>
    <p class="mb-5 card-text">MP 34567</p>
    </div><div class="card-footer"><a href="#" class="especialidades btn btn-sm">Contactar</a></div>
  
        </div>
    </div>
  
  
    <div class="border-0 me-lg-4 my-lg-4 col card column Fonoaudiología">
      <div class="h-100 card ">
  <img src="https://www.bizkaiatalent.eus/wp-content/uploads/2014/05/ETB_Estibaliz-Ruiz-de-Azua1.jpg" class="img-thumbnail card-img-top border-0" alt="mountains">
  <div class="card-body">
    <h5 class="card-title">Elena</h5>
    <p class="card-text">Fonoaudiologa</p>
    <p class="mb-5 card-text">MP 34567</p>
    </div><div class="card-footer"><a href="#" class="especialidades btn btn-sm">Contactar</a></div>
  
        </div>
    </div>
  
  
    <div class="border-0 me-lg-4 my-lg-4 col card column Fisioterapia">
      <div class="h-100 card">
  <img src="https://www.bizkaiatalent.eus/wp-content/uploads/2014/05/ETB_Estibaliz-Ruiz-de-Azua1.jpg" class="img-thumbnail card-img-top border-0" alt="mountains">
  <div class="card-body">
    <h5 class="card-title">Susana</h5>
    <p class="card-text">Fisioterapia</p>
    <p class="mb-5 card-text">MP 34567</p>
    </div><div class="card-footer"><a href="#" class="especialidades btn btn-sm">Contactar</a></div>
  
        </div>
    </div>
 

<!-- END GRID -->
</div> 
        
    


</div>


<?php include 'footer.html'; ?>

该表单正在移动设备上显示,并且可以选择,但无法过滤/工作。它有什么问题? 提前谢谢!

【问题讨论】:

  • 乍一看,我发现您正在监听&lt;option&gt; 元素上的onclick 事件。这些元素在移动设备上的呈现方式不同,并且(可能)不会触发这些事件。而是在父 &lt;select&gt; 事件上监听 change 事件并根据当前选择的 value 进行过滤。
  • 谢谢 Emiel 但它仍然无法正常工作,我改变了你告诉我的内容:

标签: javascript html css forms bootstrap-5


【解决方案1】:

从 select 元素中删除所有事件侦听器。它应该类似于下面的示例。

<select id="select1" class="form-select" aria-label="Default select example">
  <option selected value="all">Todos</option>
  <option value="Fisioterapia">Fisioterapia</option>
  <option value="Fonoaudiología">Fonoaudiología</option>
  <option value="Psicología">Psicología</option>
</select>

然后在您的 JavaScript 文件中添加一个事件侦听器。这将侦听#select1 元素上的change 事件。每当发生更改时,它都会获取选择元素的当前值(即选定选项的值)并将其传递给filterSelection 调用。

$(document).ready(function() {
  $('#select1').on('change', function() {
    const value = $(this).val();
    filterSelection(value);
  });
});

【讨论】:

    最近更新 更多