JQuery :: Click Event Fires On Second Click But Not On First
Sep 30, 2011JQuery click event fires on second click but not on first. I have had this happend before some time ago.
View 6 RepliesJQuery click event fires on second click but not on first. I have had this happend before some time ago.
View 6 Repliesi generated a subnode for all unordered lists which are Childs of List-Elements like this:
<ul>
<li>1</li>
<li>2
<ul>
[Code].....
I create buttons from an array of objects that such as:
buttons = [{ text: "button 1", action: 1}, {text: "button 2", action: 2}];
I then loop thru the array to assign the text and bind the click event after having created the buttons with IDs of "button_<index>".
for( var index in buttons ) {
$("#button_"+index).html ( buttons[index].text )
.click( function() { clickButton( buttons[index].action ) } );
}
The text appears correctly in the button, but every button defined only fires the list bound click, in this example the action equal to'2'whether I push "Button 1" or "Button 2".My actual case has four buttons, all firing the event for the fourth button.I've tried not chaining the .click(), going thru the loop twice once for the .html and once for the .click, neither of which made a difference. If I hard code each button .click, it works fine.
I've got a button toolbar, and users can select rows in a table. When they have selected some row's, they can click one of the buttons, and it invokes a callback. Problem is, when I click the first time, there's nothing wrong. But when I click the second time, it fires the callback two times, when I click the third time it fires the callback three times, and so on. That's a big problem, since the button is used to delete a page, and obviously it should delete it only once, since the AJAX would return an error ortherwise. The code is seperated in three blocks, first the the onclick on the button object, which invokes a function called confirmAction, taking to parameters. [1], a message for the users, [2] the name of the callback unction. When the confirmation is confirmed, the confirmAction function calls the callback. As said before, when I click #delete once, it behaves like expected. But when I click the second time (without refresh) it runs the callback function twice, third time thrice, and so on.
[code]
$('#delete').click(function() {
confirmAction('Weet je zeker dat je de geselecteerde pagina's wilt
verwijderen?', 'destroy');
});
[Code].....
I add multiple items with each click and then I want to remove them one by one by clicking. All is ok, but if I add 2-3 items and the click the first one, confirmation alert fires multiple times when i click Cancel. The number of times depends on how many items goes after curent.
Code:
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/
TR/html4/strict.dtd">
<html>
[code]....
How can I give a click on a link when it is just created and added to DOM?
None of this works:
function openProfilePage(profile){
$('#profile-link').remove();
var link = $('<a/>').attr({'href':'profile.php?user='+profile, 'target':'_blank', 'id':'profile-link'}).css({'top':'-200px','left':'-300px', 'position':'absolute'}).html(profile);
[Code]...
I would like to create a plugin that I can put before a click event on a button. The click event should occur if the user's time on the page hasn't expired. The plugin should check the user's time, and then stop the click event if the time has expired. With the plugin, I'm essentially putting two click events on the same button, as I need to check the expiration when the button is clicked. The plugin is working on my test page, but I'm afraid that this is contingent on an arbitrary ordering of the click events by jQuery. If I have my click event chained after my plugin, can I be assured that the plugin would always stop the click event if the time is expired? Or could jQuery execute the click event before the time gets checked?
(function( $ ){
$.fn.checkExpiration = function(
$this = $(this);
return this.each(function(){3
[Code].....
I want to call the click event of the link (anchor tag) on the click of the button. I used this code below in the click event of button to call links click event and it works fine in IE.
document.getElementById('linktag').click();
But, this doesn't work in Firefox. I googled a bit and found that in firefox, you have to do something more to achieve this behaviour. So, I ended up doing this on button click to work in firefox:
var link=document.getElementById('linktag');
var e = document.createEvent('MouseEvents');
e.initEvent(
[code]....
The above code does the click on link when I click on the button. But my problem now is that I have defined a link as
<a href="mailto:abc@xyz.com?subject=abc&body=email body">email </a>
and when click is called and mailto links opens my email client, it somehow ignores the subject and body parameters of the link. It works properly when i actually click a link element. but it doesn't work when i simulate the click event by code written above. above dispatching event code somehow ignores the link parameters?
Firstly, I dont even know if this is possible but anyway I have a HTML form element problem, I want to be able to double click one item in a multi select box and I want that double click to fire of a modal popup box.
I am able to get a regular hyperlink to do the action for me but I need it to be an item in a multi select box.
I have uploaded an example of my problem here,[url].
so for example i would like a popup to appear when you double click "volvo" just like the popup appears for the hyperlink at the bottom.
I cant really figure this out, the only thing i could see messing it up is the javascript:void(0) inside the anchor link but since there is a double click function and a click, it should only be one click.I put autoOpen which i think is also causing it, but i did that so theuser can open it, close it, and open it again so the delay "double click" is saying for the first time initialize and then the second click is opening?? if so how do i get around this?
HERE IS MY JQUERY
$(document).ready(function(){
$("#pro_edit_profile").hide();[code]....
HERE IS MY HTML FOR THE LINK
<a href="javascript:void(0);" id="pro_edit_pic_link" name="Change
Profile Picture">Change Profile Picture</a>
There is a checkbox on a form page, when you check it, a div will become visible with some extra inputs needed for that situation. To simulate this click on the checkbox external, I use click(). With jquery files 1.4 and lower this works properly and like expected. When using jquery library 1.4.1 or higher, something does not seem to work properly. Sooooo, the code:
<script type="text/javascript" src="http://code.jquery.com/jquery-1.4.min.js"></script>
<!--<script type="text/javascript" src="http://code.jquery.com/jquery-1.6.1.min.js"></script>-->
<script type="text/javascript">[code]....
Somehow I managed to get this thing 'sort of' working with 1.4.1 or higher. But the code to accomplish this is absurd. See functioncheckTheBox4Plus() on line 8. It works :) but shouldn't.. Or is it the other way around?
I have an object that has a click event I'm trying to trigger. However in the click event I have the following if statement:
if(event.button != 0){return true;}
This if statement allows right clicks to go through and activate but it also prevents me from triggering the event. Any ideas on how to prevent this? If I remove the if statement from the first click function everything works as intended.Here's my example code based off of the trigger event examples:
<!DOCTYPE html>
<html>
<head>
[code]....
I have a situation on my website similar to this:
<ul id="menu1" class="menu">
<li>
<a href='javascript:myFunction(0)'>Hello</a>
</li>
</ul>
This makes a link that calls myFunction(0) when I click it. Now I want to add a popup whenever the user clicks the link (but I can't add it to myFunction for some reason), so I add an event listener to this <a> in the $(document).ready() function:
$('ul.menu li a').click(
function() {
alert("hi");
});
Now the the popup does appear, but it doesn't execute myFunction(0) anymore.
So finally my question: is there a way to pass my <a>'s href to this click-function and makes it execute? Or is there a better way?
I want to execute a function, when a user clicks on a certain button on my page. It works in Chrome, Safari, Opera and FF, but not in IE 9. The jquery-Code looks like this:
$('#mapButton').click(function(event){ ... });
My HTML source code:
<div id="medias">
<div>AUDIO<br /><p id="audioButton"></p></div>
<div>KARTE<br /><p id="mapButton"></p></div>
<div>BILDER<br /><p id="galleryButton"></p></div>
<br style="clear:both"/>
</div>
By Clicking on mapButton the function should follow. I tried it first with the input-Tag, then with the a-Tag and afterwards with the p-Tag. Nothing works at all. I also inserted a return false at the end of my JS function. How to handle it?
In my current work i try to put several links onto an image. I do this with AJAX:
$('.panorama').load("getContents.php", {id : "5"});
This inserts several links into my container "panorama". They look like that: <a class='poi' style='margin-top:141px; margin-left:365px;' href='#6'></a>
The problem is, that a click on those links is not registrated by my java-script
code. I tried it this way:
$('a.poi').click(function(){
var hash = $(this).attr("href").substr(1);
console.log(hash);
if(hash)
[Code].....
build that js for a drupal module. The function "Drupal.open_upload_modal" is called on every click (alerts), but why is the click event only working once after page load?
<a href="#upload" onclick="Drupal.open_upload_modal();" title="upload">SAVE</a>
// $Id: automodal_upload.js,v 1.1.2.7 2009/12/28 02:21:20 Exp $
(function ($) {
Drupal.open_upload_modal = function(){
[Code].....
Okay I have a div element which has a click event for deleting it but I also have sub li elements with click events for deleting them, problem is if I click a sub element the click event is also triggered for the parent how can I ensure it only triggers on the topmost visible element?
View 1 Replies View RelatedI don't know but I had a click event for a button but it works only once. So if I click that button works, my function works, if I click it again, it doesn't get executed again.
View 4 Replies View RelatedI'm new to jQuery. I'm writing some code to show a picture if user clicks on table row. This is the table
<table id="restable" border="0">
<thead><tr>
<th class="cat" width="150"><a href="">Category</a></th>
<th class="brand" width="150"><a href="">Brand</a></th>
<th class="name" width="300"><a href="">Name</a></th>
<th class="weight" width="50"><a href="">Weight</a></th>
</tr></thead>
<tbody id="table">
</tbody>
</table>
The table is filled with this function
function search(sortt,dirt) {
$.getJSON("/jsonsearch.php", {cat: $("select#catselect").val(), brand:
$("select#brandselect").val(), name: $("input#search").val(), sort:
sortt, dir: dirt}, function(j){
$("tbody#table").empty();
var row='';
for (var i = 0; i < j.length; i++) {
row="<tr><td width='150'>"+j[i].cats+"</td><td width='150'>"+j
[i].brand+"</td><td class='name' width='300'>"+j[i].name+"</td><td
width='50'>"+j[i].weight+"</td></tr>";
$("#restable tbody").append(row);
}})
This is the function I put inside $(document).ready()
$("#table td").click(function(){
alert("jhgjgh");
});
The problem is that click event doesn't fire. If I get it working, how do I get the contents of the row that user clicked. I need Name from that row.
i'm appending a child div in a parent div. parent div has alreadychild div's which have classes ws_c1 and plus.
$
'<div></div>'
.addClass
[code]....
I know that it should work in those browsers, so hopefully someone can tell me where I'm going wrong.I created a function....it does not sit inside the document.ready function, so maybe that is part of the issue. I am not sure how to accomplish this another way. Wasn't sure how to pass an argument to the function using an anonymous function in document.ready. The idea is to have a side navigation panel that shows/hides divs on the page. I am creating a website for my upcoming wedding and want to do it all on one page and just fade in the divs. If I click on 'ceremony' for example, I want it to hide any open divs, then show the ceremony div. For the divs I always want on the page, I gave a class of 'static.' That is the reason for the 'not' condition in the code. I hope I have explained clearly enough. Here is the code,Btw, this does work in firefox6 and ie9 without issue.Here is the javascript:
function showDiv(showThis){
$(this).click(function() {
$('#containers > div:not(.static)').css('display','none');
[code]....
I have this code where takes the page a few seconds to load the page up.. in the meanwhile there are some links that I don't want any one to click..
View 1 Replies View RelatedI have 2 div with the same id, and i call a function onmouseenter. It works very well across all browsers except IE7 where the first div work but the second one does not run the function.
[Code]...
I would like to substitute the following lines with a loop, such that I do not have to copy them countless times... (array stores jQuery-objects / with the $ in front)array[0].click(function() { someFunction(0); });
[Code]...
Can someone please explain the reason for this (I'm guessing the assignment only 'lives' during execution of the loop-cycle) and maybe suggest a way around it?
I have created a function, function test [code]...
I want to bind this function for click event using $('#btnsave').bind("click",function(){}) in jquery
How can i do this?
I am having difficulty binding a popup to a text link.
The following code works:
CSS:
/* COPY LINK CSS */
#copylink {
position: absolute;
top: 170px;
[Code].....