Functions | Documentation - Roblox Creator Hub (2024)

Functions are blocks of code that you can execute multiple times on command. You can also connect them to events or assign them as callbacks.

Basic Functions

A function definition includes:

  • The scope of the function (global or local).

  • The function keyword.

  • The name of the function in camelCase.

  • The parameters of the function in parentheses (()).

  • The block of code, or "body", of the function.

  • The end keyword.

The body of the function executes when you call the function. To call a function, type its name followed by parentheses. You can define a variable to accept the return value or use the return value in place of a variable.

-- This function has no parameters and returns nil

local function addOneAndTwo()

local result = 1 + 2

print(result)

end

-- Calling a function without a return

addOneAndTwo() -- 3

Parameters

Parameters are variables that you make available to the function and are only used in the function's scope. Functions have no parameters by default. If you call a function with more parameters than it expects, Luau ignores the extra parameters. If you call a function with fewer parameters than it expects, Luau passes nil for all missing parameters.

-- This function has two parameters: num1 and num2

local function addNumbers(num1, num2)

print(num1 + num2)

end

addNumbers(2, 3) -- 5

addNumbers(5, 6, 7) -- 11

addNumbers(9) -- attempt to perform arithmetic (add) on number and nil

Return

In the body of the function, the return keyword returns a result from a computation. You can return multiple values from one function. return ends function execution, and Luau expects the end keyword to follow the return statements, so writing code between the return command and the end command throws an error.

-- This function returns one return value

local function addNumbers(num1, num2)

local result = num1 + num2

return result

end

print(addNumbers(1, 2)) -- 3

local seven = addNumbers(3, 4)

print(seven) -- 7

-- This function returns multiple values: sum and difference

local function addAndSubtract(num1, num2)

local sum = num1 + num2

local difference = num1 - num2

return sum, difference

end

-- Calling a function and expecting multiple return values

local sum, difference = addAndSubtract(2, 3)

print(sum) -- 5

print(difference) -- -1

Methods

Methods are functions that are members of an object, such as a class or table. They expect the object itself (self) as the first argument. When you call a method, use the colon notation (:) instead of dot notation (.) to pass self as the first argument automatically.

All objects in Roblox descend from Instance and have commonly used methods including Instance:Destroy(), Instance:Clone(), and Instance:FindFirstChild().

-- Destroying a Part with dot notation (function)

local firstPart = Instance.new("Part")

firstPart.Parent = workspace

print(firstPart.Parent) -- Workspace

firstPart.Destroy(firstPart)

print(firstPart.Parent) -- nil

-- Destroying a Part with colon notation (method)

local secondPart = Instance.new("Part")

secondPart.Parent = workspace

print(secondPart.Parent) -- Workspace

secondPart:Destroy()

print(secondPart.Parent) -- nil

Defining Methods

To create a method in a table, use the name of the method as the key and the method function as the value. In the definition of the method, the self parameter refers to the method's parent table. When you call a method using colon notation, you pass the table itself as the first argument. You can define parameters for a method, but you need to list them after the self parameter.

In the following example, the testButton table has a method as the value of the changeEnabled key. You can verify that self refers to the method's parent table by printing the value of self.enabled.

local testButton = {

enabled = true,

changeEnabled = function(self, isEnabled)

self.enabled = isEnabled

print(self.enabled)

end

}

print(testButton.enabled) -- true

-- Call the method

testButton:changeEnabled(false) -- false

Callbacks

Callbacks are functions that execute in response to another function or process. Some Global.RobloxGlobals functions, such as delay() and spawn(), take callbacks as parameters. In the Roblox Studio API, callbacks are write-only members of some classes. Unlike event handlers, callbacks yield until they return. Widely used callbacks include:

  • MarketplaceService.ProcessReceipt, which handles developer products purchases.

  • BindableFunction.OnInvoke, which calls the function when a script calls BindableFunction:Invoke(...).

  • RemoteFunction.OnClientInvoke, which calls the function when the server calls RemoteFunction:FireClient(player, ...) or RemoteFunction:FireAllClients(...).

  • RemoteFunction.OnServerInvoke, which calls the function when a client calls RemoteFunction:InvokeServer(...).

Setting Callbacks

To set a callback, assign a function to it. For example, BindableFunction.OnInvoke is a callback of BindableFunction. You can set a named or anonymous function to it, and you can call (invoke) that function by calling the :Invoke() method on the callback. The arguments you pass to :Invoke() forward to the callback, and the return value from the callback function returns to the caller of :Invoke().

local bindableFunction = Instance.new("BindableFunction")

bindableFunction.OnInvoke = function(number)

return 2 * number

end

print(bindableFunction:Invoke(42)) -- 84

Function Techniques

Event Handlers

You can assign a function, known as an event handler, to execute when an event fires. For example, you can create a function called onPlayerAdded() to the Players.PlayerAdded event to print the name of whatever player joins. For more information, see Events.

local Players = game:GetService("Players")

local function onPlayerAdded(player)

print(player.Name .. " joined the game!")

end

Players.PlayerAdded:Connect(onPlayerAdded)

Anonymous Functions

You can create functions without names, known as anonymous functions, to use as callbacks and event handlers. Like named functions, anonymous functions need to start and end with the function and end keywords, but you don't need the local keyword to indicate local scope because they always have local scope.

In the following example, the callback for the task.delay() function and the event handler for the Players.PlayerAdded event are both anonymous functions.

-- Anonymous function in a callback to task.delay()

task.delay(2, function(exactTimeElapsed)

print(exactTimeElapsed) -- 2.0064592329945

end)

-- Anonymous function in an event handler

local Players = game:GetService("Players")

Players.PlayerAdded:Connect(function(player)

print(player.Name .. " joined the game!")

end)

Functions in ModuleScripts

You can reuse functions across multiple scripts by storing them in ModuleScripts. Functions are a Luau data type, so you can store them in tables with other data.

Variadic Functions

A variadic function accepts any number of arguments. For example, print() is a variadic function.

print(2, "+", 2, "=", 2 + 2) --2 + 2 = 4

print(string.format("The %s is a %s!", "cake", "lie")) -- The cake is a lie!

print(string.char(115, 101, 99, 114, 101, 116)) -- secret

Defining Variadic Functions

To define a variadic function, you use the ... token as the last or only parameter (not to be confused with .., the concatenation operator). You can put the ... values in a table for ease of use.

local function variadic(named, ...)

local arguments = {...} -- pack the extra arguments into a table

print("Named argument =", named)

for i, value in arguments do

print("Input No.", i, "=", value)

end

end

variadic(10, "Hi", 20, "Variadic Function")

--[[ Resulting output:

Named argument = 10

Input No. 1 = Hi

Input No. 2 = 20

Input No. 3 = Variadic Function

]]

Argument Forwarding

You can define variadic functions as wrappers around other functions to pass, or forward, arguments from the wrapper to the other functions.

local function printAround(functionToPrintAround, ...)

print("Before")

functionToPrintAround(...)

print("After")

end

local function addNumbers(x, y, z)

print("x =", x)

print("y + z =", y + z)

end

printAround(addNumbers, 1, 2, 3)

--[[ Resulting output:

Before

x = 1

y + z = 5

After

]]

Calling a Variadic Function with Arrays

If you want to pass a table array of values to a global variadic function, such as print(), you can use the global unpack() function to pass the values of the table instead of the table itself.

local squares = {1, 4, 9, 16, 25}

print("The first 5 square numbers are:", unpack(squares))

-- The first 5 square numbers are 1 4 9 16 25

Functions | Documentation - Roblox Creator Hub (2024)
Top Articles
Topics | Dangerous Minds
Alexandra Pierce Reviews Song of the Huntress by Lucy Holland
Target Dummies 101 - The Dummy Research/Tutorial Thread
0.0Gomovies
Convert Ng Dl To Pg Ml
Things to do in Wichita Falls on weekends 12-15 September
Valentina Gonzalez Leak
Pokewilds Wiki
Busted Newspaper Williamsburg Ky
Jacy Nittolo Ex Husband
Roilog Com Payment
Half Inning In Which The Home Team Bats Crossword
Craigslis Nc
Minnesota Gophers Highlights
Cloud Cannabis Utica Promo Code
Which Expression Is Equivalent To Mc016-1.Jpg
Oklahoma City Municipal Courthouse
Mhrb Near Me
MLB The Show 23 Marketplace: Your Ultimate Guide to Trading and Collecting - Belvidere Youth Baseball
M&T Home Equity Loan Calculator
Ihub Fnma Message Board
Craigslist St. Paul
Redgifs.comn
Desi Cinemas.com
Find Words Containing Specific Letters | WordFinder®
Midsouthshooters Supply
Sun Commercial Obituaries
Belly Button Torture Video
Cia Decrypter
Eros Cherry Hill
Yillian Atkinson Velez
Exploring The Craigslist Washington DC Marketplace - A Complete Overview
Shannon Sharpe Pointing Gif
Https //Paperlesspay.talx.com/Gpi
Wolf Of Wallstreet 123 Movies
Rare Rides: The 1970 Chevrolet Chevelle SS454 LS6 Convertible - Street Muscle Rare Rides
Babymukki
Längen umrechnen • m in mm, km in cm
Cars for Sale by Owner in San Francisco, CA
DePaul joins nationwide pro-Palestinian college protests as encampment continues at University of Chicago
Grayson County Craigslist
Every Act That's Auditioned for AGT Season 18 So Far
Flixtor The Meg
The Stock Exchange Kamas
1 Filmy4Wap In
Cetaphil Samples For Providers
Mnps Payroll Calendar 2022-23
Kayla Simmons Of Leak
Registrar Lls
4215 Tapper Rd Norton Oh 44203
Craigslist Sf Jobs Food And Beverage
Craigslist Org Las Vegas Cars
Latest Posts
Article information

Author: Melvina Ondricka

Last Updated:

Views: 5659

Rating: 4.8 / 5 (48 voted)

Reviews: 87% of readers found this page helpful

Author information

Name: Melvina Ondricka

Birthday: 2000-12-23

Address: Suite 382 139 Shaniqua Locks, Paulaborough, UT 90498

Phone: +636383657021

Job: Dynamic Government Specialist

Hobby: Kite flying, Watching movies, Knitting, Model building, Reading, Wood carving, Paintball

Introduction: My name is Melvina Ondricka, I am a helpful, fancy, friendly, innocent, outstanding, courageous, thoughtful person who loves writing and wants to share my knowledge and understanding with you.