php - 语法问题 - 如果进行另一个选择则隐藏和显示选择器

标签 php jquery css-selectors

我被这段代码困住了。从各方面来看,它应该可以工作,我已经盯着它看了两个小时了,我不知道出了什么问题。

我有两个选项,div 中有选项。当使用正确的父 id 选择一个时,子类别应该出现,但由于某种原因它没有出现,尽管我觉得我已经做得很好 - 这是我的主页 html/php:

<li>
            <label for="Catid">Pick a Category:</label>
            <select id="Catid">
              <?php
                  $Products = New Products();
                  $Products->form_Cat_Picker();
                ?>
            </select>
          </li>
          <li>
            <label for="Subcatid">Sub Category:</label>
              <?php
                  $Products = New Products();
                  $Products->form_Subcat_Picker();
                ?>
          </li>
          <script type="text/javascript">
            $(document).ready(function() {
                $('#Catid').change(function(){
                    var optvalue = $(this).val(),
                    div = $('#' + 'parentid' + optvalue);
                    $('div').hide();
                    div.show();
                });
            });​
          </script>
          <li>

这是两个函数:

function form_Cat_Picker() {
    $mysqli = new mysqli(DB_SERVER, DB_USER, DB_PASSWORD, DB_NAME);
    if (!$mysqli) {
        die('There was a problem connecting to the database.');
    }       
    $catPicker = "SELECT Catid, Catname
            FROM ProductCats
            ORDER BY Catid";
    if ($Result = $mysqli->query($catPicker)){
        if (!$Result) {
            echo 'Could not run query: ' . mysql_error();
            exit;
        }
        echo '<option value="">'.''.'</option>';
        while ($row = $Result->fetch_assoc()) {
            echo '<option value="'.$row["Catid"].'">'.$row["Catname"]."</option>";
            echo '</div>';
        }
    }
    $mysqli->close();
}
function form_Subcat_Picker() {
    $mysqli = new mysqli(DB_SERVER, DB_USER, DB_PASSWORD, DB_NAME);
    if (!$mysqli) {
        die('There was a problem connecting to the database.');
    }       
    $catPicker = "SELECT Subcatid, Subcatname, Parentid
            FROM ProductSubCats
            ORDER BY Subcatid";
    if ($Result = $mysqli->query($catPicker)){
        if (!$Result) {
            echo 'Could not run query: ' . mysql_error();
            exit;
        }
        $counter = 0;
        while ($row = $Result->fetch_assoc()) { 
            if ($counter >= 1) {
                if ($last_id != $row['Parentid']){
                    echo '</select>';
                    echo '</div>';
                }
            }
            if ($last_id != $row['Parentid']){
                    echo '<div id="parentid'.$row['Parentid'].'" style="display:none">';
                    echo '<select id="Subcatid">';
                }
            echo '<option value="'.$row["Subcatid"].'">'.$row["Subcatname"]."</option>";
            $last_id = $row['Parentid'];
            $counter++;
        }
        echo '</select>';
        echo '</div>';
    }
    $mysqli->close();
}

这些输出如下:

<li>
<label for="Catid">Pick a Category:</label>
<select id="Catid">
<option value=""/>
<option value="1">Sample 1</option>
<option value="2">Sample 2</option>
<option value="3">Sample 3</option>
<option value="4">Sample 4</option>
<option value="5">Sample 5</option>
<option value="6">Sample 6</option>
<option value="7">Sample 7</option>
</select>
</li>
<li>
<label for="Subcatid">Sub Category:</label>
<div id="parentid1" style="display: none;">
<select id="Subcatid">
<option value="1">Sub Sample 1</option>
<option value="2">Sub Sample 2</option>
</select>
</div>
</li>

所以输出看起来不错。 jquery 看起来是正确的。 但是当我尝试运行它时 - 选择示例 1 时,div id Parentid1 不会出现。

我是瞎了还是做错了什么?谢谢

编辑

甚至可以在 jfiddle 中使用: http://jsfiddle.net/VGDwm/ 我正确地调用了 jquery 库:

<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.8.0/jquery.min.js" type="text/javascript"/>

可能出了什么问题? jquery应该在div之后还是之前?或者这是从 php 调用时出现的问题?

最佳答案

  1. 不要在每个函数中都重新连接到数据库
  2. 重新输入jquery的最后一行,它的末尾有一个隐藏字符。

所以这里突出显示的行:

      <script type="text/javascript">
        $(document).ready(function() {
            $('#Catid').change(function(){
                var optvalue = $(this).val(),
                div = $('#' + 'parentid' + optvalue);
                $('div').hide();
                div.show();
            });
        });​    <----- THIS LINE ------>
      </script>

关于php - 语法问题 - 如果进行另一个选择则隐藏和显示选择器,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14075184/

相关文章:

php - Laravel 5.1 队列作业 $this->delete() 不工作

php - 如何将不同的数据合并到一个表行多列中?

javascript - jQuery:在事件处理期间事件对象是否隐式传递?

javascript - Colorbox 未将边框图像的宽度和高度添加到图像尺寸中

javascript - 跳过 :first-child selector 上的隐藏元素

php - 如何获取 $node 中的 html 而不仅仅是 $nodeValue

php - 如果投票为 0,则投票结果查询未获取候选人

javascript - 使用 AngularJS 像 JQuery 一样操作 DOM?

html - 粘性页脚无法与侧边栏一起正常工作

java - Jsoup 从 .text() 中排除 child