Jump to content
php.lv forumi
  • 0

Jquery remove un add Class


Question

Posted

Sveiki.

mana funkcija kura nostradā tikai vienu reizi. Šī funkcijas man no false parveido uz true klasi bet taja paša laika no true uz false neparveido.

function setTrue(test){
   $('#StatusID' + test).removeClass().addClass('False');
   alert('id'+ test);
} 

function setFalse(test){
   $('#StatusID' + test).removeClass().addClass('True');
   alert('id'+ test);
} 

Mēģināju arī removeClass('True') šis ar nepalīdzēja.

 

Kā lai panāk lai visu laiku varetu slēgāt?

7 answers to this question

Recommended Posts

  • 0
Posted

Atrisināju. nezinu vai lābākais varinats bet stradā.

function setStatus(test){

   fds = $('#StatusID' + test).attr('class');
   if(fds == 'False')
       $('#StatusID' + test).toggleClass('True');

   $('#StatusID' + test).toggleClass('False');
} 

  • 0
Posted

Ja gribi pārbaudīt vai klase eksistē, tad izmanto .hasClass() vai .is()

 

Pamēģini tā

function setStatus(test){
 var $el = $('#StatusID' + test),
     count = $el.data('toggle')||0;
 $el.toggleClass('False')
    .toggleClass('True', count % 2 === 1)
    .data('toggle',++count);
}

  • 0
Posted (edited)

man dati tiek no datu bazes vilkti ara un tad jau uzreiz es skatos pec ta stausa tad piešķiru klasi.

pirmais el   <div id='StatusID<?=row['id']?>' class='sTrue' onclick="setStatus(<?=$row['id']?>)"></div>
otrais el    <div id='StatusID<?=row['id']?>' class='sTrue' onclick="setStatus(<?=$row['id']?>)"></div>
trešais el   <div id='StatusID<?=row['id']?>' class='sFalse' onclick="setStatus(<?=$row['id']?>)"></div>
ceturtais el <div id='StatusID<?=row['id']?>' class='sTrue' onclick="setStatus(<?=$row['id']?>)"></div>

 

marcis rakstija šādu variantu

function setStatus(test){
 $("#StatusID"+test).toggleClass("sTrue sFalse");
}

 

bet šis nestrādā.

Edited by reiniger
  • 0
Posted (edited)

marcis variants, protams, nestrādās. Dokumentācijā jau rakstīts, ka toggleClass('True False') "togglēs" abas klases vienlaicīgi, nevis pēc kārtas.

Ja klases jau ir pieliktas, tad labāks šāds variants

function setStatus(test){
 var $el = $('#StatusID' + test);
 $el.toggleClass('False')
    .toggleClass('True', (function(){return !$el.hasClass('False');})());
}

Edited by indoom

Join the conversation

You can post now and register later. If you have an account, sign in now to post with your account.

Guest
Answer this question...

×   Pasted as rich text.   Paste as plain text instead

  Only 75 emoji are allowed.

×   Your link has been automatically embedded.   Display as a link instead

×   Your previous content has been restored.   Clear editor

×   You cannot paste images directly. Upload or insert images from URL.

Loading...
×
×
  • Create New...