The input element with a type attribute whose value is week represents a control for setting the element’s value to
a string representing a week.
Instantiate the Week class using Week::widget().
$week = Week::widget();The generateField method is used to generate the field id and name for the HTML output.
Allowed arguments are:
modelName- The name of the model.fieldName- The name of the field.arrayable- Whether the field is an array. For default, it isfalse.
// generate field id and name
$week->generateField('model', 'field');Use the provided methods to set specific attributes for the a element.
// setting class attribute
$week->class('container');Or, use the attributes method to set multiple attributes at once.
$week->attributes(['class' => 'container', 'style' => 'background-color: #eee;']);If you want to include value in the week element, use the value method.
$week->value('MyValue');Generate the HTML output using the render method, for simple instantiation.
$html = $week->render();Or, use the magic __toString method.
$html = (string) $week;Below are examples of common use cases:
// adding multiple attributes
$week->class('external')->value('Myvalue');
// using data attributes
$week->dataAttributes(['analytics' => 'trackClick']);Explore additional methods for setting various attributes such as lang, name, style, title, etc.
Use prefix and suffix methods to add text before and after the week tag, respectively.
// adding a prefix
$html = $week->value('MyValue')->prefix('MyPrefix')->render();
// adding a suffix
$html = $week->value('MyValue')->suffix('MySuffix')->render();The template method allows you to customize the HTML output of the a element.
The following template tags are available:
| Tag | Description |
|---|---|
{prefix} |
The prefix text. |
{tag} |
The a element. |
{suffix} |
The suffix text. |
// using a custom template
$week->template('<div>{tag}</div>');Refer to the Attribute Tests for comprehensive examples.
The following methods are available for setting attributes:
| Method | Description |
|---|---|
ariaDescribedBy() |
Set the aria-describedby attribute. |
ariaLabel() |
Set the aria-label attribute. |
attributes() |
Set multiple attributes at once. |
autofocus() |
Set the autofocus attribute. |
class() |
Set the class attribute. |
dataAttributes() |
Set multiple data-attributes at once. |
dirName() |
Set the dirname attribute. |
disabled() |
Set the disabled attribute. |
form() |
Set the form attribute. |
hidden() |
Set the hidden attribute. |
id() |
Set the id attribute. |
lang() |
Set the lang attribute. |
name() |
Set the name attribute. |
readOnly() |
Set the readonly attribute. |
style() |
Set the style attribute. |
tabIndex() |
Set the tabindex attribute. |
title() |
Set the title attribute. |
value() |
Set the value attribute. |
Refer to the Custom Methods Tests for comprehensive examples.
The following methods are available for customizing the HTML output:
| Method | Description |
|---|---|
generateField() |
Generate the field id and name for the HTML output. |
prefix() |
Add text before the textarea element. |
prefixContainer() |
Set enabled or disabled for the prefix-container element. |
prefixContainerAttributes() |
Set attributes for the prefix-container element. |
prefixContainerClass() |
Set the class attribute for the prefix-container element. |
prefixContainerTag() |
Set the tag for the prefix-container element. |
render() |
Generates the HTML output. |
suffix() |
Add text after the label element. |
suffixContainer() |
Set enabled or disabled for the suffix-container element. |
suffixContainerAttributes() |
Set attributes for the suffix-container element. |
suffixContainerClass() |
Set the class attribute for the suffix-container element. |
suffixContainerTag() |
Set the tag for the suffix-container element. |
template() |
Set the template for the HTML output. |
widget() |
Instantiates the Week::class. |
Refer to the Validate Tests for comprehensive examples.
| Method | Description |
|---|---|
max() |
Set the max attribute. |
min() |
Set the min attribute. |
step() |
Set the step attribute. |
required() |
Set the required attribute. |