javascript - jQuery .toggleClass() speed - Stack Overflow

I use jQuery .toggleClass() function, class will toggled per click, that works perfectly, but i can

I use jQuery .toggleClass() function, class will toggled per click, that works perfectly, but i can't setup speed, i have tried this:

$('#databox').toggleClass('boxopened', 7000);

also this:

$('#databox').toggleClass('boxopened', 'easeInQuad');

and also this:

I have add latest jquery 1.10 and jqueryUI: 1.10.3

It's possible to setup speed?

I use jQuery .toggleClass() function, class will toggled per click, that works perfectly, but i can't setup speed, i have tried this:

$('#databox').toggleClass('boxopened', 7000);

also this:

$('#databox').toggleClass('boxopened', 'easeInQuad');

and also this: http://forum.jquery./topic/hover-and-toggleclass-fail-at-speed

I have add latest jquery 1.10 and jqueryUI: 1.10.3

It's possible to setup speed?

Share Improve this question asked Jul 24, 2013 at 14:39 Mirko SimicMirko Simic 671 gold badge2 silver badges9 bronze badges 1
  • 1 Checked the docs for you. .toggleClass does not support speed - you need .animate. – Brian Commented Jul 24, 2013 at 14:42
Add a ment  | 

5 Answers 5

Reset to default 6

Add to your classes:

CSS:

    -webkit-transition:0.4s;
    -moz-transition:0.4s;
    -ms-transition:0.4s;
    -o-transition:0.4s;
    transition:0.4s;

This "transition declaration" will force the timer , if its not working try adding !important or give us some code to inspect.

HERE IS A DEMO:

JSnippet Demo

Ensure that you are including JQuery UI Effects - the base JQuery does not allow transitions on show/hide/toggle, it's added as an extension from UI Effects. (In your app, or in browser console, try running $.ui.version)

http://api.jqueryui./toggleClass/

EDIT:Works for me on $.ui.version => "1.10.3" (the version you requested). Here's a demo: http://jsfiddle/yKFjA/1/

What styling changes are being applied that you wish to see animated?

You might consider setting the speed via CSS3 transitions; the answer I gave to similar question can get you started if that interests you. @Shlomi Hassid also provides similar advice.

This has some advantages

  • simplification of code,
  • separation of concerns,
  • possibly better performance by handing off the job to the browser,
  • definitely better performance on older browsers

and disadvantages -- inconsistent browser implementations mean anywhere from slight differences to non-functional (on older browsers, though I think the performance benefit outweighs the consistency benefit).

Try this:

$('#databox').toggleClass('boxopened', 1000, 'easeInQuad');

If you want to delay the change in class, use setTimeout:

setTimeout( function(){

$('#databox').toggleClass('boxopened');

}, 7000 };

发布者:admin,转转请注明出处:http://www.yc00.com/questions/1743655753a4485340.html

相关推荐

  • javascript - jQuery .toggleClass() speed - Stack Overflow

    I use jQuery .toggleClass() function, class will toggled per click, that works perfectly, but i can

    1天前
    10

发表回复

评论列表(0条)

  • 暂无评论

联系我们

400-800-8888

在线咨询: QQ交谈

邮件:admin@example.com

工作时间:周一至周五,9:30-18:30,节假日休息

关注微信