4

我一生都无法弄清楚我错过了什么。

这个 jsFiddle中,我在 dom 上隐藏了一个带有两个文本框的 div。我想在下拉列表中选择特定选项时显示 div。

这是被隐藏/显示的 div:

<div id="movieAddNewDirector">
  <label id="lblMovieAddDirector">Add a New Director:</label>
  <br />
  <label for="txtMovieAddNewDirectorFirstName">First Name:</label>
  <input type="text" name="txtMovieAddNewDirectorFirstName" id="txtMovieAddNewDirectorFirstName" size="20" />
  <br />
  <label for="txtMovieAddNewDirectorLastName">Last Name:</label>
  <input type="text" name="txtMovieAddNewDirectorLastName" id="txtMovieAddNewDirectorLastName" size="20" />
</div>

这是相关的jQuery代码

$('#ddlMovieAddDirector').change(function () {    
    var id = $(this).find('option:selected').attr('id');

    alert('id: ' + id);

    if (id == '#optMovieAddDirectorNew') {
      alert('attempting to show new director div');
      $('#movieAddNewDirector').show();
    } else {
      alert('id didn\'t match - id: ' + id);
      $('#movieAddNewDirector').hide();
    }
});

“id 不匹配”始终显示,即使选择第二个选项时,显示检测到的 id 的第一个警报显示应该显示 div 的正确 id!

我知道我在 jQuery 中有正确的 ID,但我不明白为什么这不起作用。对于显示/隐藏 div 的单选按钮选择,我有一些非常相似的工作。

任何帮助将不胜感激!

4

1 回答 1

7

改变if (id == '#optMovieAddDirectorNew') {

对此:if (id == 'optMovieAddDirectorNew') {

“#”符号不是 id 的一部分,它仅用于在选择器中查找 id

和 JSfiddle http://jsfiddle.net/BG4Dg/1/

于 2013-01-14T22:48:57.587 回答