Referencing previous nodes#
When working with data in n8n, you'll often need to reference information from the current node or from previous nodes in your workflow.
Common ways of referencing#
The most frequently used methods for accessing data are:
$json: Access JSON data from the current input item$('<node-name>').item.json: Access JSON data from a linked item in a previous node
Other referencing methods#
These methods work in both expressions and the Code node:
| Method | Description |
|---|---|
$binary |
Access binary data from the current input item |
$input.item |
The input item currently being processed |
$('<node-name>').first() |
Get the first item from a specified node |
$('<node-name>').last() |
Get the last item from a specified node |
$('<node-name>').all() |
Get all items from a specified node |
Current node input#
Methods for working with the input of the current node. Some methods and variables aren't available in the Code node.
Python support
You can use Python in the Code node. It isn't available in expressions.
| Method | Description | Available in Code node? |
|---|---|---|
$binary |
Shorthand for $input.item.binary. Incoming binary data from a node |
|
$input.item |
The input item of the current node that's being processed. Refer to Item linking for more information on paired items and item linking. | |
$input.all() |
All input items in current node. | |
$input.first() |
First input item in current node. | |
$input.last() |
Last input item in current node. | |
$input.params |
Object containing the query settings of the previous node. This includes data such as the operation it ran, result limits, and so on. | |
$json |
Shorthand for $input.item.json. Incoming JSON data from a node. Refer to Data structure for information on item structure. |
|
$input.context.noItemsLeft |
Boolean. Only available when working with the Loop Over Items node. Provides information about what's happening in the node. Use this to determine whether the node is still processing items. |
| Method | Description |
|---|---|
_input.item |
The input item of the current node that's being processed. Refer to Item linking for more information on paired items and item linking. |
_input.all() |
All input items in current node. |
_input.first() |
First input item in current node. |
_input.last() |
Last input item in current node. |
_input.params |
Object containing the query settings of the previous node. This includes data such as the operation it ran, result limits, and so on. |
_json |
Shorthand for _input.item.json. Incoming JSON data from a node. Refer to Data structure for information on item structure. Available when you set Mode to Run Once for Each Item. |
_input.context.noItemsLeft |
Boolean. Only available when working with the Loop Over Items node. Provides information about what's happening in the node. Use this to determine whether the node is still processing items. |
Output of other nodes#
Methods for working with the output of other nodes. Some methods and variables aren't available in the Code node.
Python support
You can use Python in the Code node. It isn't available in expressions.
| Method | Description | Available in Code node? |
|---|---|---|
$("<node-name>").all(branchIndex?, runIndex?) |
Returns all items from a given node. If branchIndex isn't given it will default to the output that connects node-name with the node where you use the expression or code. |
|
$("<node-name>").first(branchIndex?, runIndex?) |
The first item output by the given node. If branchIndex isn't given it will default to the output that connects node-name with the node where you use the expression or code. |
|
$("<node-name>").last(branchIndex?, runIndex?) |
The last item output by the given node. If branchIndex isn't given it will default to the output that connects node-name with the node where you use the expression or code. |
|
$("<node-name>").item |
The linked item. This is the item in the specified node used to produce the current item. Refer to Item linking for more information on item linking. | |
$("<node-name>").params |
Object containing the query settings of the given node. This includes data such as the operation it ran, result limits, and so on. | |
$("<node-name>").context |
Boolean. Only available when working with the Loop Over Items node. Provides information about what's happening in the node. Use this to determine whether the node is still processing items. | |
$("<node-name>").itemMatching(currentNodeInputIndex) |
Use instead of $("<node-name>").item in the Code node if you need to trace back from an input item. |
| Method | Description | Available in Code node? |
|---|---|---|
_("<node-name>").all(branchIndex?, runIndex?) |
Returns all items from a given node. If branchIndex isn't given it will default to the output that connectsnode-name with the node where you use the expression or code. |
|
_("<node-name>").first(branchIndex?, runIndex?) |
The first item output by the given node. If branchIndex isn't given it will default to the output that connects node-name with the node where you use the expression or code. |
|
_("<node-name>").last(branchIndex?, runIndex?) |
The last item output by the given node. If branchIndex isn't given it will default to the output that connects node-name with the node where you use the expression or code. |
|
_("<node-name>").item |
The linked item. This is the item in the specified node used to produce the current item. Refer to Item linking for more information on item linking. | |
_("<node-name>").params |
Object containing the query settings of the given node. This includes data such as the operation it ran, result limits, and so on. | |
_("<node-name>").context |
Boolean. Only available when working with the Loop Over Items node. Provides information about what's happening in the node. Use this to determine whether the node is still processing items. | |
_("<node-name>").itemMatching(currentNodeInputIndex) |
Use instead of _("<node-name>").item in the Code node if you need to trace back from an input item. Refer to Accessing linked items in the Code node for an example. |
This page was