jQuery click event not firing in jQueryMobile -


using jquery jquery-1.9.1.js , jquerymobile 1.3.1 (chrome 26/windows 7) cannot see why 1 of these 'click' events bound #one1 fires , other doesn't:

html:

<div data-role="page" id="one" data-theme="a">     <div data-role="header" data-position="inline">         <h1>one</h1>     </div>     <div data-role="content" data-theme="a">         <a href="#" id="one1">[one]</a>         <a href="#two">two</a>         <a href="#three">three</a>     </div> </div> 

javascript:

<script> $(document).on( "mobileinit", function() {     $(document).on('click', '#one1', function(e){         console.log('firing');     });     $('#one1').on("click", function() {         console.log('not firing');     }); });  </script> 

when run in jsfiddle both events fire when not wrapped in "mobileinit" event: http://jsfiddle.net/9nrwa/

what missing here?

intro

first thing first, mobileinit event should not used event binding. while can used mobileinit not created purpose. created jquery mobile parameter auto-initialization, should not used event binding.

correct way use proper page events pageinit. more information page events take @ other answer covers various jquery mobile page events , difference towards usual jquery document ready paradigm: jquery mobile: document ready vs page events.

not let me answer question. events click can bound in few different ways. lets @ examples have used:

various ways of event binding jquery

first example

$(document).on('click', '#one1', function(e){     console.log('firing'); }); 

this first example new came use first deprecated method live. it's event delegation mechanism allows bind event handlers not existing instances of given node type, future instances of given node type (by "type" mean set of dom nodes matched given jquery selector). want here is, during event binding element don't need exist in dom, method works binding event handlers document , reacting events bubble through dom. doesn't matter if element #one1 exist or not during event binding. can create dynamically later , still work.

second example

$('#one1').on("click", function() {     console.log('not firing'); }); 

this on old way of event binding. requires event exists in dom before event can bind. in case trying bind click event element didn't exist in dom @ point in time. doesn't matter loaded after binding process.

working example

jsfiddle example: http://jsfiddle.net/gajotres/qmnsa/

take @ example. there see 5 different ways of click event binding in jquery mobile:

  • 2 click event bound in head, before page initialized dom
  • 2 click events bound in head in pagebeforeshow event, delegation of binding because event bound when page shown , inside dom
  • 1 click event bound in body after page content. because content loaded inside dom @ point click event work.

html :

<!doctype html> <html>     <head>         <title>jqm complex demo</title>         <meta name="viewport" content="width=device-width; initial-scale=1.0; maximum-scale=1.0; minimum-scale=1.0; user-scalable=no; target-densitydpi=device-dpi"/>         <link rel="stylesheet" href="http://code.jquery.com/mobile/1.3.1/jquery.mobile-1.3.1.min.css" />         <script src="http://code.jquery.com/mobile/1.3.1/jquery.mobile-1.3.1.min.js"></script>             <script>                 $(document).on('click', '#one1', function(e){                     // example work because bind event delegation process                     console.log('firing 1');                 });                 $('#one1').on("click", function() {                     // example not work because event not exist in moment                     console.log('not firing');                 });                 $(document).on( "pagebeforeshow", function() {                     // example work because bind event delegation process                                 $(document).on('click', '#one1', function(e){                         console.log('firing 2');                     });                     // example work because element exist in dom during pagebeforeshow event                     $('#one1').on("click", function() {                         console.log('firing 3');                     });                 });                      </script>     </head>     <body>         <div data-role="page" id="index">             <div data-theme="b" data-role="header">                 <h1>index page</h1>             </div>              <div data-role="content">                 <a href="#" id="one1" data-role="button">[one]</a>             </div>         </div>             <script>             $('#one1').on("click", function() {                 // example  work because binding when element loaded dom                 console.log('firing 4');             });                     </script>     </body> </html>    

conclusion

  • do not use mobileinit event event binding, trigger before page loaded dom , events bind delegation work.
  • bind events in correct jquery mobile page events.

usefull links regarding topic:

  1. jquery live() method , event bubbling

    while live method deprecated on method should used instead. in benchmarks on method 2x faster.

  2. jquery mobile: document ready vs page events

  3. various jquery mobile page events
  4. what “event bubbling” mean?

Comments

Popular posts from this blog

c++ - Function signature as a function template parameter -

algorithm - What are some ways to combine a number of (potentially incompatible) sorted sub-sets of a total set into a (partial) ordering of the total set? -

How to call a javascript function after the page loads with a chrome extension? -