Tipo di campo file

Il tipo file rappresenta un input per caricare file.

Reso come campo input file
Opzioni
Opzioni ereditate
Tipo genitore form
Classe Symfony\Component\Form\Extension\Core\Type\FileType

Utilizzo di base

Si supponga di avere in un form:

$builder->add('attachment', 'file');

Quando il form viene inviato, il campo attachment sarà un’istanza di Symfony\Component\HttpFoundation\File\UploadedFile. Può essere usata per spotare il file attachment in una posizione permanente:

use Symfony\Component\HttpFoundation\File\UploadedFile;

public function uploadAction()
{
    // ...

    if ($form->isValid()) {
        $someNewFilename = ...

        $form['attachment']->getData()->move($dir, $someNewFilename);

        // ...
    }

    // ...
}

Il metodo move() accetta come parametri una cartella e un nome di file. Si può calcolare il nome del file in uno dei modi seguenti:

// usare il nome del file originale
$file->move($dir, $file->getClientOriginalName());

// calcolare un nome casuale e provare a indovinare l'estensione (più sicuro)
$extension = $file->guessExtension();
if (!$extension) {
    // l'estensione non può essere indovinata
    $extension = 'bin';
}
$file->move($dir, rand(1, 99999).'.'.$extension);

L’uso del nome originale, tramite getClientOriginalName(), non è sicuro, perché potrebbe essere stato manipolato dall’utente. Inoltre, può contenere caratteri che non sono consentiti nei nomi di file. Si dovrebbe ripulire il nome prima di utilizzarlo direttamente.

Leggere il ricettario per un esempio di come gestire un caricamento di file associato con un’entità Doctrine.

Opzioni

multiple

Nuovo nella versione 2.5: L’opzione multiple è stata introdotta in Symfony 2.5.

tipo: Booleano predefinito: false

Se impostata a true, l’utente potrà caricare più file contemporaneamente.

Opzioni ereditate

Queste opzioni sono ereditate dal tipo form:

disabled

type: booleano default: false

Se non si vuole che l’utente modifichi il valore di un campo, si può impostare questa opzione a true. Ogni valore inserito sarà ignorato.

empty_data

tipo: mixed

Il valore predefinito è null.

Questa opzione determina il valore restituito dal campo quando viene selezionato placeholder.

Si può personalizzare a seconda delle esigenze. Per esempio, se si vuole che il campo gender sia impostato a null quando non viene scelto alcun valore, lo si può fare in questo modo:

$builder->add('gender', 'choice', array(
    'choices' => array(
        'm' => 'Maschio',
        'f' => 'Femmina'
    ),
    'required'    => false,
    'placeholder' => 'Scegliere un genere',
    'empty_data'  => null
));

Nota

Se si vuole impostare l’opzione empty_data per l’intera classe del form, vedere la ricetta Configurare dati vuoti per una classe Form.

error_bubbling

tipo: booleano predefinito: false

Se true, qualsiasi errore per questo campo sarà passato al campo genitore o al form. Per esempio, se impostato a true su un campo normale, qualsiasi errore per il campo sarà collegato al form principale, non al campo stesso.

error_mapping

tipo: array predefinito: empty

Questa opzione consente di modificare il bersaglio di un errore di validazione.

Si immagini di avere un metodo personalizzato, di nome matchingCityAndZipCode, che valida se una città e un codice postale corrsispondano. Purtroppo non c’è un campo “matchingCityAndZipCode” nel form, quindi tutto ciò che può fare Symfony è mostrare l’errore in cima al form stesso.

Con la mappatura personalizzata degli errori, si può fare meglio: mappare l’errore al campo della città, in modo che sia mostrato accanto a esso:

public function setDefaultOptions(OptionsResolverInterface $resolver)
{
    $resolver->setDefaults(array(
        'error_mapping' => array(
            'matchingCityAndZipCode' => 'city',
        ),
    ));
}

Ecco le regole per i lati destro e sinistro della mappatura:

  • I lato sinistro contiene i percorsi delle proprietà.
  • Se la validazione è generata su una proprietà o metodo di una classe, il suo percorso è semplicemente “nomeProprietà”.
  • Se la validazione è generata su un elemento di un array od oggetto ArrayAccess, il percorso è [nomeIndice].
  • Si possono costruire percorsi innestati, concatenandoli, separando le proprietà con dei punti. Per esempio: addresses[work].matchingCityAndZipCode
  • Anche il lato sinistro della mappatura accetta un punto ., che si riferisce al campo stesso. Questo significa che un errore aggiunto al campo è aggiunto invece al dato campo innnestato.
  • Il lato destro contiene semplicemente i nomi dei campi nel form.

label

tipo: stringa predefinito: “indovinato” dal nome del campo

Imposta la label usata per la resa del campo. La label può anche essere inserita direttamente all’interno del template:

{{ form_label(form.name, 'Il tuo nome') }}

label_attr

tipo: array predefinito: array()

Imposta gli attributi HTML per l’elemento <label>, che saranno usati durante la resa della label di un campo. È un array associativo con gli attributi HTML come chiavi. Questi attributi possono anche essere impostati all’interno del template:

  • Twig
    {{ form_label(form.name, 'Nome', {'label_attr': {'class': 'CUSTOM_LABEL_CLASS'}}) }}
    
  • PHP
    echo $view['form']->label(
        $form['name'],
        'Nome',
        array('class', 'CUSTOM_LABEL_CLASS')
    );
    

mapped

tipo: booleano

Se si vuole che il campo sia ignorato durante la lettura o la scrittura dell’oggetto, si può impostare l’opzione mapped a false

read_only

tipo: booleano predefinito: false

Se questa opzione è true, il campo sarà reso con l’attributo disabled, in modo che il campo non sia modificabile.

required

tipo: booleano predefinito: true

Se true, sarà reso un attributo required HTML5. La label corrispondente sarà anche resa con una classe required.

L’attributo è indipendente dalla validazione del form. Nel caso migliore, se si lascia che Symfony indovini il tipo di campo, il valore di questa opzione sarà indovinato dalle informazioni di validazione.

Variabili di form

Variabile Tipo Uso
type stringa La variabile tipo è impostata a file, per poter essere reso come campo input file

Tabella dei contenuti

Argomento precedente

Tipo di campo checkbox

Argomento successivo

Tipo di campo radio

Questa pagina