Projekt

Allgemein

Profil

« Zurück | Weiter » 

Revision 5551a36b

Von Moritz Bunkus vor fast 12 Jahren hinzugefügt

  • ID 5551a36b8f059aa03a371fb5a851c116d305fccb
  • Vorgänger f50ddd66
  • Nachfolger 341fbe8b

ClientJS: jQuery-Funktionen addClass, removeClass, toggleClass; Utility-Funktion "action_if"; Doku

Unterschiede anzeigen:

SL/ClientJS.pm
58 58
  removeProp   => 2,
59 59
  val          => 2,
60 60

  
61
  # Class attribute
62
  addClass     => 2,
63
  removeClass  => 2,
64
  toggleClass  => 2,
65

  
61 66
  # Data storage
62 67
  data         => 3,
63 68
  removeData   => 2,
......
123 128
  return $self;
124 129
}
125 130

  
131
sub action_if {
132
  my ($self, $condition, @args) = @_;
133

  
134
  return $condition ? $self->action(@args) : $self;
135
}
136

  
126 137
sub init__actions {
127 138
  return [];
128 139
}
......
338 349

  
339 350
The first variation is obviously better suited for chaining.
340 351

  
341
Additional functions:
352
=over 4
353

  
354
=item C<action $method, @args>
355

  
356
Call the function with the name C<$method> on C<$self> with arguments
357
C<@args>. Returns the return value of the actual function
358
called. Useful for chaining (see above).
359

  
360
=item C<action_if $condition, $method, @args>
361

  
362
Call the function with the name C<$method> on C<$self> with arguments
363
C<@args> if C<$condition> is trueish. Does nothing otherwise.
364

  
365
Returns the return value of the actual function called if
366
C<$condition> is trueish and C<$self> otherwise. Useful for chaining
367
(see above).
368

  
369
This function is equivalent to the following:
370

  
371
  if ($condition) {
372
    $obj->$method(@args);
373
  }
374

  
375
But it is easier to integrate into a method call chain, e.g.:
376

  
377
  $js->html('#content', $html)
378
     ->action_if($item->is_flagged, 'toggleClass', '#marker', 'flagged')
379
     ->render($self);
380

  
381
=back
382

  
383
=head2 ADDITIONAL FUNCTIONS
342 384

  
343 385
=over 4
344 386

  
js/client_js.js
71 71
      else if (action[0] == 'removeProp')           $(action[1]).removeProp(action[2]);
72 72
      else if (action[0] == 'val')                  $(action[1]).val(action[2]);
73 73

  
74
      // Class attribute
75
      else if (action[0] == 'addClass')             $(action[1]).addClass(action[2]);
76
      else if (action[0] == 'removeClass')          $(action[1]).removeClass(action[2]);
77
      else if (action[0] == 'toggleClass')          $(action[1]).toggleClass(action[2]);
78

  
74 79
      // Data storage
75 80
      else if (action[0] == 'data')                 $(action[1]).data(action[2], action[3]);
76 81
      else if (action[0] == 'removeData')           $(action[1]).removeData(action[2]);

Auch abrufbar als: Unified diff