gsap.from()
Returns : Tween
For a quick overview, check out this video from the "GSAP 3 Express" course by Snorkl.tv - one of the best ways to learn the basics.
Think of a gsap.from()
like a backwards tween where you define where the values should START, and then it animates to the current state which is perfect for animating objects onto the screen because you can set them up the way you want them to look at the end and then animate in from elsewhere. For example:
// animate ".class" from an opacity of 0 and a y position of 100 (like transform: translateY(100px))
// to the current values (an opacity of 1 and y position of 0).
gsap.from(".class", { opacity: 0, y: 100, duration: 1 });
loading...
Since GSAP can animate any property of any object, you are NOT limited to CSS properties or DOM objects. Go crazy. You may be surprised by how many things can be animated by GSAP and it "just works".
To control the Tween instance later, assign it to a variable (GSAP is conveniently object-oriented):
let tween = gsap.from(".class", {
rotation: 360,
duration: 5,
ease: "elastic",
});
//now we can control it!
tween.pause();
tween.seek(2);
tween.progress(0.5);
tween.play();
To simply fire off animations and let them run, there's no need to use variables. Tweens play immediately by default (though you can set a delay
or paused
value) and when they finish, they automatically dispose of themselves. Call gsap.from()
as much as you want without worrying about cleanup.
However, from tweens can be a little tricky. One of the most common GSAP mistakes is misusing them. Make sure to use them responsibly!
Other types of tweens:
- to() - You define the end values to animate to, GSAP uses the current values as the start values.
- fromTo() - You define the starting and ending values.
Parameters
- targets - The object(s) whose properties you want to animate. This can be selector text like
".class"
,"#id"
, etc. (GSAP usesdocument.querySelectorAll()
internally) or it can be direct references to elements, generic objects, or even an array of objects - vars - An object containing all the properties/values you want to animate, along with any special properties like
ease
,duration
,delay
, oronComplete
(listed below).
Special Properties
Add any of these to your vars
object to give your animation special powers:
- The scope to be used for all of the callbacks (onStart, onUpdate, onComplete, etc.).
- Assign arbitrary data to this property (a string, a reference to an object, whatever) and it gets attached to the tween instance itself so that you can reference it later like
yourTween.data
. - Amount of delay before the animation should begin (in seconds).
- The duration of the animation (in seconds). Default:
0.5
- Controls the rate of change during the animation, giving it a specific feel. For example,
"elastic"
or"strong.inOut"
. See the Ease Visualizer for a list of all of the options.ease
can be a String (most common) or a function that accepts a progress value between 0 and 1 and returns a converted, similarly normalized value. Default:"power1.out"
- Allows you to (optionally) assign a unique identifier to your tween instance so that you can find it later with
gsap.getById()
and it will show up in GSDevTools with that id. - Normally a tween waits to render for the first time until the very next tick (update cycle) unless you specify a delay. Set
immediateRender: true
to force it to render immediately upon instantiation. Default:false
for to() tweens,true
for from() and fromTo() tweens or anything with a scrollTrigger applied. - Normally tweens inherit from their parent timeline's
defaults
object (if one is defined), but you can disable this on a per-tween basis by settinginherit: false
. - When a tween renders for the very first time and reads its starting values, GSAP will try to delay writing of values until the very end of the current "tick" which can improve performance because it avoids the read/write/read/write layout thrashing that browsers dislike. To disable lazy rendering for a particular tween, set
lazy: false
. In most cases, there's no need to setlazy
. To learn more, watch this video. Default:true
(except for zero-duration tweens) - A function to call when the animation has completed
- An Array of parameters to pass the onComplete function. For example,
gsap.to(".class", {x:100, onComplete:myFunction, onCompleteParams:["param1", "param2"]});
- A function to call when the animation is interrupted, meaning if/when the tween is killed before it completes. This could happen because its kill() method is called or due to overwriting.
- An Array of parameters to pass the onInterrupt function. For example,
gsap.to(".class", {x:100, onInterrupt:myFunction, onInterruptParams:["param1", "param2"]});
. - A function to call each time the animation enters a new iteration cycle (repeats). Obviously this only occurs if you set a non-zero
repeat
. - An Array of parameters to pass the onRepeat function.
- A function to call when the animation has reached its beginning again from the reverse direction (excluding repeats).
- An Array of parameters to pass the onReverseComplete function.
- A function to call when the animation begins (when its time changes from 0 to some other value which can happen more than once if the tween is restarted multiple times).
- An Array of parameters to pass the onStart function.
- A function to call every time the animation updates (on each "tick" that moves its playhead).
- An Array of parameters to pass the onUpdate function.
- If
true
, all tweens of the same targets will be killed immediately regardless of what properties they affect. If"auto"
, when the tween renders for the first time it hunt down any conflicts in active animations (animating the same properties of the same targets) and kill only those parts of the other tweens. Non-conflicting parts remain intact. Iffalse
, no overwriting strategies will be employed. Default:false
- If
true
, the animation will pause itself immediately upon creation. Default:false
- How many times the animation should repeat. So
repeat: 1
would play a total of two iterations. Use -1 to repeat infinitely. Default:0
- Amount of time to wait between repeats (in seconds). Default:
0
- Setting
repeatRefresh: true
causes a repeating tween toinvalidate()
and re-record its starting/ending values internally on each full iteration (not including yoyo's). This is useful when you use dynamic values (relative, random, or function-based). For example,x: "random(-100, 100)"
would get a new random x value on each repeat.duration
,delay
, andstagger
do NOT refresh. - If
true
, the animation will start out with its playhead reversed, meaning it will be oriented to move toward its start. Since the playhead begins at a time of 0 anyway, a reversed tween will appear paused initially because its playhead cannot move backward past the start. - If
true
, the animation will invert its starting and ending values (this is what a from() tween does internally), though the ease doesn't get flipped. In other words, you can make ato()
tween into afrom()
by settingrunBackwards: true
. - If multiple targets are defined, you can easily stagger the start times for each by setting a value like
stagger: 0.1
(for 0.1 seconds between each start time). Or you can get much more advanced staggers by using a stagger object. For more information, see the stagger documentation. - Defines starting values for any properties (even if they're not animating). For example,
startAt: {x: -100, opacity: 0}
- If
true
, every otherrepeat
iteration will run in the opposite direction so that the tween appears to go back and forth. This has no affect on thereversed
property though. So ifrepeat
is2
andyoyo
isfalse
, it will look like: start - 1 - 2 - 3 - 1 - 2 - 3 - 1 - 2 - 3 - end. But ifyoyo
istrue
, it will look like: start - 1 - 2 - 3 - 3 - 2 - 1 - 1 - 2 - 3 - end. Default:false
- Allows you to alter the ease in the tween's
yoyo
phase. Set it to a specific ease like"power2.in"
or set it totrue
to simply invert the tween's normalease
. Note: GSAP is smart enough to automatically setyoyo: true
if you define anyyoyoEase
, so there's less code for you to write. Default:false
- To animate the targets to various states, use
keyframes
- an array of vars objects that serve asto()
tweens. For example,keyframes: [{x:100, duration:1}, {y:100, duration:0.5}]
. All keyframes will be perfectly sequenced back-to-back, but you can define adelay
value to add spacing between each step (or a negative delay would create an overlap).
Property
Description
Plugins
A plugin adds extra capabilities to GSAP's core. Some plugins make it easier to work with rendering libraries like PIXI.js or EaselJS while other plugins add superpowers like morphing SVG shapes, adding drag and drop functionality, etc. This allows the GSAP core to remain relatively small and lets you add features only when you need them. See the full list of plugins here.
Function-based values
Get incredibly dynamic animations by using a function for any value, and it will get called once for each target the first time the tween renders, and whatever is returned by that function will be used as the value. This can be very useful for applying conditional logic or randomizing things (though GSAP has baked-in randomizing capabilities too...scroll down for that).
gsap.from(".class", {
x: 100, //normal value
y: function(index, target, targets) { //function-based value
return index \* 50;
},
duration: 1
});
The function is passed three parameters:
- index - The index of the target in the array. For example, if there are 3
<div>
elements with the class ".box", and yougsap.from(".box", ...)
, the function gets called 3 times (once for each target); the index would be0
first, then1
, and finally2
. - target - The target itself (the
<div>
element in this example). - targets - The array of targets (same as
tween.targets()
).
Random values
Define random values as a string like "random(-100, 100)"
for a range or like "random([red, blue, green])"
for an array and GSAP will swap in a random value for each target accordingly! This makes advanced randomized effects simple. You can even have the random number rounded to the closest increment of any number! For example:
gsap.from(".class", {
x: "random(-100, 100, 5)", //chooses a random number between -100 and 100 for each target, rounding to the closest 5!
});
Or use an array-like value and GSAP will randomly select one of those:
gsap.from(".class", {
x: "random([0, 100, 200, 500])", //randomly selects one of the values (0, 100, 200, or 500)
});
There's also a gsap.utils.random()
function that you can use directly if you prefer.
Relative values
Use a"+="
or "-="
prefix to indicate a relative value. For example, gsap.from(".class", {x: "-=20"});
will animate x
20 pixels less than whatever it is when the tween starts. {x: "+=20"}
would add 20. To use a variable in a relative way, simply add the "+="
or "-="
prefix, like {x: "+=" + yourVariable}
.
Staggers
If multiple targets are defined, you can easily stagger (offset) the start times for each by setting a value like stagger: 0.1
(for 0.1 seconds between each start time). Or you can get much more advanced staggers by using a stagger object. For more information, see the stagger documentation.
Sequencing
For basic sequencing, you could use a delay
on each tween (like gsap.from(".class", {
delay: 0.5, duration: 1, x: 100})
), but we strongly recommended using a Timeline
for all but the simplest sequencing tasks because it gives you much greater flexibility, especially when you're experimenting with timing. It allows you to append tweens one-after-the-other and then control the entire sequence as a whole. You can even have the tweens overlap as much as you want, nest timelines as deeply as you want, and much, much more.
Timelines have convenient to(), from(), and fromTo() methods as well so you can very easily chain them together and build complex sequences:
let tl = gsap.timeline(); //create the timeline
tl.from(".class1", { x: 100 }) //start sequencing
.to(".class2", { y: 100, ease: "elastic" })
.to(".class3", { rotation: 180 });
By default, immediateRender
is true
in from()
tweens, meaning that they immediately render their starting state regardless of any delay that is specified. You can override this behavior by passing immediateRender: false
in the vars
parameter so that it will wait to render until the tween actually begins (often the desired behavior when inserting into Timelines). So the following code will immediately set the opacity
of obj
to 0 and then wait 2 seconds before tweening the opacity back to 1 over the course of 1.5 seconds:
gsap.from(obj, { duration: 1.5, opacity: 0, delay: 2 });
Callbacks
Callbacks are functions that are called after certain events happen in a tween or timeline like when they start, complete, repeat, reverse complete, or update. They can be very useful for debugging, keeping different parts of your project in sync, and many other things.
To learn more about GSAP's callbacks, check out this video from the "GSAP 3 Express" course by Snorkl.tv - one of the best ways to learn the basics of GSAP 3.