-
-
Notifications
You must be signed in to change notification settings - Fork 3
Type safe getters
The Input
class has type-safe getter functions assigned to it via the InputValueGetter
trait:
getString(string $key):?string
getMultipleString(string $key):array<string>
getInt(string $key):?int
getMultipleInt(string $key):array<int>
getFloat(string $key):?float
getMultipleFloat(string $key):array<float>
getBool(string $key):?bool
getMultipleBool(string $key):array<bool>
getFile(string $key):?FileUpload
getMultipleFile(string $key):array<FileUpload>
getDateTime(string $key):?DateTimeInterface
getMultipleDateTime(string $key):array<DateTimeInterface>
The singular functions like getString
, getInt
, etc. all return nullable types. That is to say, they will attempt to return a typed value of the corresponding user input, but will return null
if there is no user input supplied for the requested key.
The multiple functions like getMultipleString
, getMultipleInt
, etc. all return an array
of the corresponding types. There may be zero elements in the array.
The getMultiple*
functions will always return an array of values, corresponding to the values entered into elements with the same name
attribute. It's important to know that PHP requires the use of square brackets within identical names. This is for two reasons: 1) to make PHP treat the incoming user input as an array; 2) to make it obvious and clear in the HTML that multiple inputs are expected.
Here's a common example of when multiple input elements may have the same name. When there's multiple elements to select using checkboxes, it makes sense for the checkboxes to share the same name. This example allows the user to make a choice of topping for their pizza.
HTML:
<form method="post">
<p>Please select your pizza toppings:</p>
<label>
<input type="checkbox" name="topping[]" value="mozzarella" />
<span>Mozzarella cheese</span>
</label>
<label>
<input type="checkbox" name="topping[]" value="spinach" />
<span>Spinach</span>
</label>
<label>
<input type="checkbox" name="topping[]" value="tomato" />
<span>Tomatoes</span>
</label>
<button name="do" value="submit">Submit</button>
</form>
PHP:
function do_submit(Pizza $pizza, Input $input):void {
// The value of $toppingsSelected is an array of strings, where
// the values are whatever values have been checked by the user.
$toppingsSelected = $input->getMultipleString("topping");
foreach($toppingsSelected as $topping) {
$pizza->addTopping($topping);
}
}
Next, learn how PHP handles files and how this library normalises the data.
PHP.Gt/Input is a separately maintained component of PHP.Gt/WebEngine.