我要做的就是生成一个带有文本输入字段和下面编码风格的按钮的表单。文本输入字段工作正常。但是,单选按钮类不是。单选按钮类应具有该组的标题,addOption
函数应使用单选按钮显示每个选项。当我测试我的代码时,没有标题“Scoops”的标题,只有一个单选按钮“Three Scoops”而不是“One Scoop”和“Two Scoops”。我究竟做错了什么?这是我的代码:
IceCreamForm.php
:
<?php
require_once 'Form.php';
require_once 'RadioButton.php';
require_once 'TextInput.php';
require_once 'Validator.php';
$form = new Form();
$form -> addInput(new TextInput("First Name: ", "firstName"));
$form -> addInput(new TextInput("Last Name: ", "lastName"));
$form -> addInput(new TextInput("Ice Cream Flavor: ", "iceCreamFlavor"));
$radio = new RadioButton("Number of Scoops: ");
$radio -> addOption("One Scoop", "one");
$radio -> addOption("Two Scoops", "two");
$radio -> addOption("Three Scoops", "three");
$form -> addInput($radio);
echo $form -> generateHTML();
Form.php
:
<?php
class Form
{
const GET = "GET";
const POST = "POST";
private $action = "someLocation.php";
private $inputs = array();
private $method = "POST";
public $form = "";
public $name = "";
function __construct()
{
}
function addInput(TextInput $input)
{
$this -> inputs[] = $input;
}
function getAction(): string
{
return $this -> action;
}
function getMethod(): string
{
return $this -> method;
}
function setAction(string $action)
{
$this -> action = $action;
return $this;
}
function setMethod(string $method)
{
$this -> method = $method;
return $this;
}
function set($param, $value)
{
$this -> $param = $value;
}
function generateHTML(): string
{
$this -> form = '<form action="' . $this -> getAction() . '"
method="' . $this -> getMethod() . '">';
foreach ($this -> inputs as $input)
{
$this -> form .= $input -> generateHTML();
}
$this -> form .= '</form>';
return $this -> form;
}
}
TextInput.php
:
<?php
class TextInput
{
const TYPE = "text";
private static $REQUIRED = "REQUIRED";
private $defaultValue;
private $id;
private $label;
private $name;
private $onNewLine;
private $required = false;
private $type;
function __construct($label = "", $name = "", $defaultValue = "", $id = "", $onNewLine = "", $required = false, $type = self::TYPE)
{
$this -> defaultValue = $defaultValue;
$this -> id = $id;
$this -> label = $label;
$this -> name = $name;
$this -> onNewLine = $onNewLine;
$this -> required = $required;
$this -> type = $type;
}
public function generateHTML():string
{
$req = "";
if ($this -> required == true)
{
$req = self::$REQUIRED;
}
return "<label>$this->label</label><input id='$this->id' type='$this->type' name='$this->name' onNewLine='$this->onNewLine' $req/><br/>";
}
}
RadioButton.php
:
<?php
require_once 'TextInput.php';
class RadioButton extends TextInput
{
const TYPE2 = "radio";
private $selected = false;
private $type;
function __construct($selected = false, $type = self::TYPE2)
{
$this -> selected = $selected;
$this -> type = $type;
}
function addOption(string $label, string $value)
{
$this -> label = $label;
$this -> value = $value;
}
public function generateHTML():string
{
$req = "";
if ($this -> required == true)
{
$req = self::$REQUIRED;
}
return "<label>$this->label</label><input id='$this->id' type='$this->type' value='$this->value' onNewLine='$this->onNewLine' $req/><br/>";
}
}
答案 0 :(得分:2)
...there's no title "Number of Scoops"...
因为您的RadioButton
构造函数没有设置标题。仅限$selected
和$type
。
...and only one radio button for "Three Scoops" and not for
"One Scoop" and "Two Scoops."...
因为您的addOption
方法会覆盖先前设置的标签和值。尝试将它们添加到数组中。
function addOption(string $label, string $value) {
$this->options[] = [
'label' => $label,
'value' => $value,
];
}
然后在你的generateHTML()
...
return join('', array_map(function($item) {
return sprintf('<label>%s</label> <input type="radio" value="%s">', $item['label'], $item['value']);
}, $this->options));