添加id并使用它的jquery脚本不起作用

时间:2015-12-16 15:24:57

标签: javascript jquery contains

我正在尝试使用我的键盘使用id单击按钮。

对于某些按钮,我必须设置ID,这实际上有效。但是一旦我尝试将键盘用于我设置id的按钮,它就无法工作。

我没有收到任何错误,因为添加id到元素工作,我有点困惑为什么我不能在代码中使用新的set id。

//setting id for first button (works)
$( "a:contains('Im Verband freigeben')" ).attr('id', 'freigabe-verband');
//setting id for second button (works aswell)
$( "a:contains('Vorheriger Einsatz')" ).attr('id', 'vorheriger-einsatz');


$( document ).keydown(function(e) {
 if (e.keyCode == 39) {
    //works, id is available, not set by me
     $("#alert_next").click();

} else if (e.keyCode == 38){
    // doesn't work, but id is set
    $("#freigabe-verband").click();

} else if (e.keyCode == 40){
    // doesn't work, but id is set
    $("#vorheriger-einsatz").click();

} 
return e.returnValue;

});

任何人都知道为什么? https://i.imgur.com/uy6oGFJ.png

3 个答案:

答案 0 :(得分:3)

要单击dom元素,请使用: -

$('#freigabe-verband')[0].click();

$('#freigabe-verband').get(0).click();

示例

$("a").attr('id', 'test');

$(document).keydown(function(e) {
	$('#test')[0].click();
});
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>

<a href="http://stackoverflow.com">link</a>

答案 1 :(得分:1)

没有意义。 我复制你的代码并创建一个plunkr,它运作良好。     http://plnkr.co/edit/Eb5QF6mB97Js41NFbr8J?p=preview

// Code goes here
$(function() {
  //setting id for first button (works)
  $( "a:contains('Im Verband freigeben')" ).attr('id', 'freigabe-verband');
  //setting id for second button (works aswell)
  $( "a:contains('Vorheriger Einsatz')" ).attr('id', 'vorheriger-einsatz');
  
  $( document ).keydown(function(e) {
   if (e.keyCode == 39) {
    //works, id is available, not set by me
     $("#alert_next").click();
  
  } else if (e.keyCode == 38){
    // arrow up
    $("#freigabe-verband").click();
  
  } else if (e.keyCode == 40){
    // arrow down
    $("#vorheriger-einsatz").click();
  
  } 
  return e.returnValue;
  
  });  
}
);
<!DOCTYPE html>
<html>

  <head>
    <script data-require="jquery@2.1.4" data-semver="2.1.4" src="https://code.jquery.com/jquery-2.1.4.js"></script>
    <link rel="stylesheet" href="style.css" />
    <script src="script.js"></script>
  </head>

  <body>
    <h1>Hello Plunker!</h1>
    <a href="#" onclick="alert('a');">Im Verband freigeben</a><br>
    <a href="#" onclick="alert('b');">Vorheriger Einsatz</a>
  </body>

</html>

答案 2 :(得分:0)

试试这个例子:

$(document).find("#vorheriger-einsatz").click();

你事后再添加到DOM,所以除非你再次搜索dom,否则它将无法找到