Variables
The Variables block allows you to create variables whose values can be updated at any point in an API. The Variables block is useful for updating a value over time in a Loop or Condition block, or for referencing a frequently used value across an API.
data:image/s3,"s3://crabby-images/30bc5/30bc5593473b3d1806e4f0412163bfa0469a12f0" alt="Variable initialized variable initialized"
Access the variable value using .value
property on the variable name (e.g., myVar.value
).
Variable scoping
Variables follow lexical scoping like variables in code. As such, a variable is available to other API blocks at the same nesting level (or below), relative to where the Variables block is defined.
data:image/s3,"s3://crabby-images/717d7/717d74cc6c182670e30e5f963e777faca15956a1" alt="Variable referenced within scope variable referenced within scope"
data:image/s3,"s3://crabby-images/243ad/243ad92bda229114c411264dadaee74bdf30f761" alt="Variable referenced outside scope variable referenced outside scope"
Updating / setting variable values
Variables are not typed so they can be updated to any value. In the example below, a variable called nextPage
is initialized to true
at the start of a backend API that is used to iterate through a paginated REST API. When a condition is met inside a While Loop further down in the API, the variable is updated to false
. This can be done with either another Variables block
or by setting the variable in code.
- Update Variable(s) with a Variables Block
- Update Variable(s) with code
Define a new Variables block in the same scope as the original Variables block, using the same variable name whose value you want to update.
data:image/s3,"s3://crabby-images/a364a/a364a6b01059bd8f42681393ace750ed7dd40557" alt="Variable updated variable updated"
Use the .set()
function call to update a variable’s value in a code block (e.g., myVar.set(“my new value”)
)
data:image/s3,"s3://crabby-images/9b989/9b98986f3ea39704399c286fb6eb3786aba324f8" alt="Set variable in code set variable in code"
You cannot initialize a variable in code. Setting the initial value requires a Variables block.