Files
react/docs/forms-it-IT.html
T
2016-03-07 20:28:40 +00:00

574 lines
30 KiB
HTML

<!DOCTYPE html>
<!--[if IE]><![endif]-->
<html>
<head>
<meta charset="utf-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">
<title>Moduli | React</title>
<meta name="viewport" content="width=device-width">
<meta property="og:title" content="Moduli | React">
<meta property="og:type" content="website">
<meta property="og:url" content="https://facebook.github.io/react/docs/forms-it-IT.html">
<meta property="og:image" content="https://facebook.github.io/react/img/logo_og.png">
<meta property="og:description" content="A JavaScript library for building user interfaces">
<meta property="fb:app_id" content="623268441017527">
<link rel="shortcut icon" href="/react/favicon.ico">
<link rel="alternate" type="application/rss+xml" title="React" href="https://facebook.github.io/react/feed.xml">
<link rel="stylesheet" href="/react/css/syntax.css">
<link rel="stylesheet" href="/react/css/codemirror.css">
<link rel="stylesheet" href="/react/css/react.css">
<script src="//use.typekit.net/vqa1hcx.js"></script>
<script>try{Typekit.load();}catch(e){}</script>
<!--[if lte IE 8]>
<script src="/react/js/html5shiv.min.js"></script>
<script src="/react/js/es5-shim.min.js"></script>
<script src="/react/js/es5-sham.min.js"></script>
<![endif]-->
<script src="/react/js/codemirror.js"></script>
<script src="/react/js/javascript.js"></script>
<script src="/react/js/react.js"></script>
<script src="/react/js/react-dom.js"></script>
<script src="/react/js/babel-browser.min.js"></script>
<script src="/react/js/live_editor.js"></script>
</head>
<body>
<div class="container">
<div class="nav-main">
<div class="wrap">
<a class="nav-home" href="/react/index.html">
<img class="nav-logo" src="/react/img/logo.svg" width="36" height="36">
React
</a>
<ul class="nav-site nav-site-internal">
<li><a href="/react/docs/getting-started.html" class="active">Docs</a></li>
<li><a href="/react/support.html">Support</a></li>
<li><a href="/react/downloads.html">Download</a></li>
<li><a href="/react/blog/">Blog</a></li>
</ul>
<ul class="nav-site nav-site-external">
<li><a href="https://github.com/facebook/react">GitHub</a></li>
<li><a href="https://facebook.github.io/react-native/">React Native</a></li>
</ul>
</div>
</div>
<section class="content wrap documentationContent">
<div class="nav-docs">
<!-- Docs Nav -->
<div class="nav-docs-section">
<h3>Quick Start</h3>
<ul>
<li>
<a href="/react/docs/getting-started.html">Getting Started</a>
</li>
<li>
<a href="/react/docs/tutorial.html">Tutorial</a>
</li>
<li>
<a href="/react/docs/thinking-in-react.html">Thinking in React</a>
</li>
</ul>
</div>
<div class="nav-docs-section">
<h3>Community Resources</h3>
<ul>
<li>
<a href="/react/docs/conferences.html">Conferences</a>
</li>
<li>
<a href="/react/docs/videos.html">Videos</a>
</li>
<li>
<a href="https://github.com/facebook/react/wiki/Complementary-Tools" class="external">Complementary Tools</a>
</li>
<li>
<a href="https://github.com/facebook/react/wiki/Examples" class="external">Examples</a>
</li>
</ul>
</div>
<div class="nav-docs-section">
<h3>Guides</h3>
<ul>
<li>
<a href="/react/docs/why-react.html">Why React?</a>
</li>
<li>
<a href="/react/docs/displaying-data.html">Displaying Data</a>
<ul>
<li>
<a href="/react/docs/jsx-in-depth.html">JSX in Depth</a>
</li>
<li>
<a href="/react/docs/jsx-spread.html">JSX Spread Attributes</a>
</li>
<li>
<a href="/react/docs/jsx-gotchas.html">JSX Gotchas</a>
</li>
</ul>
</li>
<li>
<a href="/react/docs/interactivity-and-dynamic-uis.html">Interactivity and Dynamic UIs</a>
</li>
<li>
<a href="/react/docs/multiple-components.html">Multiple Components</a>
</li>
<li>
<a href="/react/docs/reusable-components.html">Reusable Components</a>
</li>
<li>
<a href="/react/docs/transferring-props.html">Transferring Props</a>
</li>
<li>
<a href="/react/docs/forms.html">Forms</a>
</li>
<li>
<a href="/react/docs/working-with-the-browser.html">Working With the Browser</a>
<ul>
<li>
<a href="/react/docs/more-about-refs.html">Refs to Components</a>
</li>
</ul>
</li>
<li>
<a href="/react/docs/tooling-integration.html">Tooling Integration</a>
</li>
<li>
<a href="/react/docs/addons.html">Add-Ons</a>
<ul>
<li>
<a href="/react/docs/animation.html">Animation</a>
</li>
<li>
<a href="/react/docs/two-way-binding-helpers.html">Two-Way Binding Helpers</a>
</li>
<li>
<a href="/react/docs/test-utils.html">Test Utilities</a>
</li>
<li>
<a href="/react/docs/clone-with-props.html">Cloning Elements</a>
</li>
<li>
<a href="/react/docs/create-fragment.html">Keyed Fragments</a>
</li>
<li>
<a href="/react/docs/update.html">Immutability Helpers</a>
</li>
<li>
<a href="/react/docs/pure-render-mixin.html">PureRenderMixin</a>
</li>
<li>
<a href="/react/docs/perf.html">Performance Tools</a>
</li>
<li>
<a href="/react/docs/shallow-compare.html">Shallow Compare</a>
</li>
</ul>
</li>
<li>
<a href="/react/docs/advanced-performance.html">Advanced Performance</a>
</li>
<li>
<a href="/react/docs/context.html">Context</a>
</li>
</ul>
</div>
<div class="nav-docs-section">
<h3>Reference</h3>
<ul>
<li>
<a href="/react/docs/top-level-api.html">Top-Level API</a>
</li>
<li>
<a href="/react/docs/component-api.html">Component API</a>
</li>
<li>
<a href="/react/docs/component-specs.html">Component Specs and Lifecycle</a>
</li>
<li>
<a href="/react/docs/tags-and-attributes.html">Supported Tags and Attributes</a>
</li>
<li>
<a href="/react/docs/events.html">Event System</a>
</li>
<li>
<a href="/react/docs/dom-differences.html">DOM Differences</a>
</li>
<li>
<a href="/react/docs/special-non-dom-attributes.html">Special Non-DOM Attributes</a>
</li>
<li>
<a href="/react/docs/reconciliation.html">Reconciliation</a>
</li>
<li>
<a href="/react/docs/webcomponents.html">Web Components</a>
</li>
<li>
<a href="/react/docs/glossary.html">React (Virtual) DOM Terminology</a>
</li>
</ul>
</div>
<div class="nav-docs-section">
<h3>Flux</h3>
<ul>
<li>
<a href="https://facebook.github.io/flux/docs/overview.html" class="external">Flux Overview</a>
</li>
<li>
<a href="https://facebook.github.io/flux/docs/todo-list.html" class="external">Flux TodoMVC Tutorial</a>
</li>
</ul>
</div>
<!-- Tips Nav -->
<div class="nav-docs-section">
<h3>Tips</h3>
<ul>
<li>
<a href="/react/tips/introduction.html">Introduction</a>
</li>
<li>
<a href="/react/tips/inline-styles.html">Inline Styles</a>
</li>
<li>
<a href="/react/tips/if-else-in-JSX.html">If-Else in JSX</a>
</li>
<li>
<a href="/react/tips/self-closing-tag.html">Self-Closing Tag</a>
</li>
<li>
<a href="/react/tips/maximum-number-of-jsx-root-nodes.html">Maximum Number of JSX Root Nodes</a>
</li>
<li>
<a href="/react/tips/style-props-value-px.html">Shorthand for Specifying Pixel Values in style props</a>
</li>
<li>
<a href="/react/tips/children-props-type.html">Type of the Children props</a>
</li>
<li>
<a href="/react/tips/controlled-input-null-value.html">Value of null for Controlled Input</a>
</li>
<li>
<a href="/react/tips/componentWillReceiveProps-not-triggered-after-mounting.html">componentWillReceiveProps Not Triggered After Mounting</a>
</li>
<li>
<a href="/react/tips/props-in-getInitialState-as-anti-pattern.html">Props in getInitialState Is an Anti-Pattern</a>
</li>
<li>
<a href="/react/tips/dom-event-listeners.html">DOM Event Listeners in a Component</a>
</li>
<li>
<a href="/react/tips/initial-ajax.html">Load Initial Data via AJAX</a>
</li>
<li>
<a href="/react/tips/false-in-jsx.html">False in JSX</a>
</li>
<li>
<a href="/react/tips/communicate-between-components.html">Communicate Between Components</a>
</li>
<li>
<a href="/react/tips/expose-component-functions.html">Expose Component Functions</a>
</li>
<li>
<a href="/react/tips/children-undefined.html">this.props.children undefined</a>
</li>
<li>
<a href="/react/tips/use-react-with-other-libraries.html">Use React with Other Libraries</a>
</li>
<li>
<a href="/react/tips/dangerously-set-inner-html.html">Dangerously Set innerHTML</a>
</li>
</ul>
</div>
</div>
<div class="inner-content">
<h1>
Moduli
<a class="edit-page-link" href="https://github.com/facebook/react/tree/master/docs/docs/07-forms.it-IT.md" target="_blank">Edit on GitHub</a>
</h1>
<div class="subHeader"></div>
<p>I componenti dei moduli come <code>&lt;input&gt;</code>, <code>&lt;textarea&gt;</code> e <code>&lt;option&gt;</code> differiscono dagli altri componenti nativi poiché possono essere alterati tramite interazione dell&#39;utente. Questi componenti forniscono interfacce che rendono più semplice gestire i moduli in risposta all&#39;interazione dell&#39;utente.</p>
<p>Per maggiori informazioni sugli eventi dell&#39;elemento <code>&lt;form&gt;</code> consulta <a href="/react/docs/events.html#form-events">Eventi dei Moduli</a>.</p>
<h2><a class="anchor" name="propriet-interattive"></a>Proprietà Interattive <a class="hash-link" href="#propriet-interattive">#</a></h2>
<p>I componenti dei moduli supportano un numero di proprietà che vengono modificate dall&#39;interazione dell&#39;utente:</p>
<ul>
<li><code>value</code>, supportato dai elementi <code>&lt;input&gt;</code> e <code>&lt;textarea&gt;</code>.</li>
<li><code>checked</code>, supportato dagli elementi <code>&lt;input&gt;</code> dal tipo <code>checkbox</code> o <code>radio</code>.</li>
<li><code>selected</code>, supportato dagli elementi <code>&lt;option&gt;</code>.</li>
</ul>
<p>In HTML, in valore di <code>&lt;textarea&gt;</code> è impostato tramite un nodo di testo figlio. In React, devi invece usare la proprietà <code>value</code>.</p>
<p>I componenti dei moduli ti permettono di reagire ai cambiamenti impostando una callback come proprietà <code>onChange</code>. La proprietà <code>onChange</code> funziona in tutti i browser e viene scatenata in risposta all&#39;interazione dell&#39;utente quando:</p>
<ul>
<li>Il <code>value</code> di <code>&lt;input&gt;</code> o <code>&lt;textarea&gt;</code> cambia.</li>
<li>Lo stato <code>checked</code> di <code>&lt;input&gt;</code> cambia.</li>
<li>Lo stato <code>selected</code> di <code>&lt;option&gt;</code> cambia.</li>
</ul>
<p>Come tutti gli eventi DOM, la proprietà <code>onChange</code> è supportata su tutti i componenti nativi e può essere usata per gestire la propagazione di eventi di cambiamento.</p>
<blockquote>
<p>Nota:</p>
<p>Per <code>&lt;input&gt;</code> e <code>&lt;textarea&gt;</code>, <code>onChange</code> rimpiazza — e dovrebbe generalmente essere utilizzata in sostituzione — il gestore di eventi <a href="https://developer.mozilla.org/en-US/docs/Web/API/GlobalEventHandlers/oninput"><code>oninput</code></a> nativo del DOM.</p>
</blockquote>
<h2><a class="anchor" name="componenti-controllati"></a>Componenti Controllati <a class="hash-link" href="#componenti-controllati">#</a></h2>
<p>Un <code>&lt;input&gt;</code> il cui <code>value</code> è impostato è un componente <em>controllato</em>. In un <code>&lt;input&gt;</code> controllato, il valore dell&#39;elemento visualizzato si riflette sempre nella sua proprietà <code>value</code>. Ad esempio:</p>
<div class="highlight"><pre><code class="language-javascript" data-lang="javascript"> <span class="nx">render</span><span class="o">:</span> <span class="kd">function</span><span class="p">()</span> <span class="p">{</span>
<span class="k">return</span> <span class="o">&lt;</span><span class="nx">input</span> <span class="nx">type</span><span class="o">=</span><span class="s2">&quot;text&quot;</span> <span class="nx">value</span><span class="o">=</span><span class="s2">&quot;Ciao!&quot;</span> <span class="o">/&gt;</span><span class="p">;</span>
<span class="p">}</span>
</code></pre></div>
<p>Ciò visualizzerà un input che ha sempre il valore di <code>value</code> impostato a <code>Ciao!</code>. Ciascuna immissione dell&#39;utente non avrà effetto sull&#39;elemento visualizzato poiché React ha dichiarato il suo <code>value</code> pari a <code>Ciao!</code>. Se volessi aggiornare il <code>value</code> in risposta all&#39;input dell&#39;utente, puoi usare l&#39;evento <code>onChange</code>:</p>
<div class="highlight"><pre><code class="language-javascript" data-lang="javascript"> <span class="nx">getInitialState</span><span class="o">:</span> <span class="kd">function</span><span class="p">()</span> <span class="p">{</span>
<span class="k">return</span> <span class="p">{</span><span class="nx">value</span><span class="o">:</span> <span class="s1">&#39;Ciao!&#39;</span><span class="p">};</span>
<span class="p">},</span>
<span class="nx">handleChange</span><span class="o">:</span> <span class="kd">function</span><span class="p">(</span><span class="nx">event</span><span class="p">)</span> <span class="p">{</span>
<span class="k">this</span><span class="p">.</span><span class="nx">setState</span><span class="p">({</span><span class="nx">value</span><span class="o">:</span> <span class="nx">event</span><span class="p">.</span><span class="nx">target</span><span class="p">.</span><span class="nx">value</span><span class="p">});</span>
<span class="p">},</span>
<span class="nx">render</span><span class="o">:</span> <span class="kd">function</span><span class="p">()</span> <span class="p">{</span>
<span class="kd">var</span> <span class="nx">value</span> <span class="o">=</span> <span class="k">this</span><span class="p">.</span><span class="nx">state</span><span class="p">.</span><span class="nx">value</span><span class="p">;</span>
<span class="k">return</span> <span class="o">&lt;</span><span class="nx">input</span> <span class="nx">type</span><span class="o">=</span><span class="s2">&quot;text&quot;</span> <span class="nx">value</span><span class="o">=</span><span class="p">{</span><span class="nx">value</span><span class="p">}</span> <span class="nx">onChange</span><span class="o">=</span><span class="p">{</span><span class="k">this</span><span class="p">.</span><span class="nx">handleChange</span><span class="p">}</span> <span class="o">/&gt;</span><span class="p">;</span>
<span class="p">}</span>
</code></pre></div>
<p>In questo esempio, stiamo semplicemente accettando il valore più recente fornito dall&#39;utente e aggiornando la proprietà <code>value</code> del componente <code>&lt;input&gt;</code>. Questo pattern semplifica l&#39;implementazione di interfacce che rispondono o validano l&#39;interazione dell&#39;utente. Ad esempio:</p>
<div class="highlight"><pre><code class="language-javascript" data-lang="javascript"> <span class="nx">handleChange</span><span class="o">:</span> <span class="kd">function</span><span class="p">(</span><span class="nx">event</span><span class="p">)</span> <span class="p">{</span>
<span class="k">this</span><span class="p">.</span><span class="nx">setState</span><span class="p">({</span><span class="nx">value</span><span class="o">:</span> <span class="nx">event</span><span class="p">.</span><span class="nx">target</span><span class="p">.</span><span class="nx">value</span><span class="p">.</span><span class="nx">substr</span><span class="p">(</span><span class="mi">0</span><span class="p">,</span> <span class="mi">140</span><span class="p">)});</span>
<span class="p">}</span>
</code></pre></div>
<p>Così si può accettare l&#39;input dell&#39;utente ma ne tronca il valore ai primi 140 caratteri.</p>
<h3><a class="anchor" name="potenziali-problemi-con-checkbox-e-radio-button"></a>Potenziali Problemi con Checkbox e Radio Button <a class="hash-link" href="#potenziali-problemi-con-checkbox-e-radio-button">#</a></h3>
<p>Fai attenzione che, allo scopo di normalizzare la gestione del cambiamento degli elementi checkbox e radio button, React usa un evento <code>click</code> al posto di un evento <code>change</code>. Nella maggior parte dei casi questo funziona nel modo previsto, tranne quando viene usato <code>preventDefault</code> in un gestore dell&#39;evento <code>change</code>. <code>preventDefault</code> impedisce al browser di aggiornare visualmente l&#39;input, anche se <code>checked</code> cambia il suo valore. Questo può essere evitato rimuovendo la chiamata a <code>preventDefault</code>, oppure effettuando il cambio del valore di <code>checked</code> tramite <code>setTimeout</code>.</p>
<h2><a class="anchor" name="componenti-non-controllati"></a>Componenti Non Controllati <a class="hash-link" href="#componenti-non-controllati">#</a></h2>
<p>Un <code>&lt;input&gt;</code> che non fornisce un <code>value</code> (o lo imposta a <code>null</code>) è un componente <em>non controllato</em>. In un <code>&lt;input&gt;</code> non controllato, il valore dell&#39;elemento visualizzato rifletterà l&#39;input dell&#39;utente. Ad esempio:</p>
<div class="highlight"><pre><code class="language-javascript" data-lang="javascript"> <span class="nx">render</span><span class="o">:</span> <span class="kd">function</span><span class="p">()</span> <span class="p">{</span>
<span class="k">return</span> <span class="o">&lt;</span><span class="nx">input</span> <span class="nx">type</span><span class="o">=</span><span class="s2">&quot;text&quot;</span> <span class="o">/&gt;</span><span class="p">;</span>
<span class="p">}</span>
</code></pre></div>
<p>Questo visualizzerà un campo di input il cui valore iniziale è vuoto. Ciascun input dell&#39;utente si rifletterà immediatamente nell&#39;elemento visualizzato. Se desideri reagire ai cambiamenti del valore, puoi usare il gestore di eventi <code>onChange</code> proprio come con i componenti controllati.</p>
<h3><a class="anchor" name="valore-predefinito"></a>Valore Predefinito <a class="hash-link" href="#valore-predefinito">#</a></h3>
<p>Se desideri inizializzare il componente con un valore non vuoto, puoi fornire una proprietà <code>defaultValue</code>. Ad esempio:</p>
<div class="highlight"><pre><code class="language-javascript" data-lang="javascript"> <span class="nx">render</span><span class="o">:</span> <span class="kd">function</span><span class="p">()</span> <span class="p">{</span>
<span class="k">return</span> <span class="o">&lt;</span><span class="nx">input</span> <span class="nx">type</span><span class="o">=</span><span class="s2">&quot;text&quot;</span> <span class="nx">defaultValue</span><span class="o">=</span><span class="s2">&quot;Ciao!&quot;</span> <span class="o">/&gt;</span><span class="p">;</span>
<span class="p">}</span>
</code></pre></div>
<p>Questo esempio funzionerà in maniera simile all&#39;esempio precedente sui <strong>Componenti Controllati</strong>.</p>
<p>Similmente, <code>&lt;input&gt;</code> supporta <code>defaultChecked</code> e <code>&lt;select&gt;</code> supporta <code>defaultValue</code>.</p>
<blockquote>
<p>Nota:</p>
<p>Le proprietà <code>defaultValue</code> e <code>defaultChecked</code> sono usate soltanto durante il rendering iniziale. Se devi aggiornare il valore in un rendering successivo, dovrai usare un <a href="#controlled-components">componente controllato</a>.</p>
</blockquote>
<h2><a class="anchor" name="argomenti-avanzati"></a>Argomenti Avanzati <a class="hash-link" href="#argomenti-avanzati">#</a></h2><h3><a class="anchor" name="perch-componenti-controllati"></a>Perché Componenti Controllati? <a class="hash-link" href="#perch-componenti-controllati">#</a></h3>
<p>Usare componenti di moduli come <code>&lt;input&gt;</code> in React presenta una difficoltà aggiuntiva, assente quando si scrive un modulo tradizionale in HTML. Ad esempio, in HTML:</p>
<div class="highlight"><pre><code class="language-html" data-lang="html"> <span class="nt">&lt;input</span> <span class="na">type=</span><span class="s">&quot;text&quot;</span> <span class="na">name=</span><span class="s">&quot;title&quot;</span> <span class="na">value=</span><span class="s">&quot;Senza titolo&quot;</span> <span class="nt">/&gt;</span>
</code></pre></div>
<p>Questo visualizza un campo di input <em>inizializzato</em> con il valore <code>Senza titolo</code>. Quando l&#39;utente modifica il campo, la <em>proprietà</em> <code>value</code> del nodo cambierà. Tuttavia, <code>node.getAttribute(&#39;value&#39;)</code> restituirà ancora il valore usato durante l&#39;inizializzazione, <code>Senza titolo</code>.</p>
<p>Diversamente dall&#39;HTML, i componenti React devono rappresentare lo stato della vista in ciascun momento e non soltanto durante l&#39;inizializzazione. Ad esempio, in React:</p>
<div class="highlight"><pre><code class="language-javascript" data-lang="javascript"> <span class="nx">render</span><span class="o">:</span> <span class="kd">function</span><span class="p">()</span> <span class="p">{</span>
<span class="k">return</span> <span class="o">&lt;</span><span class="nx">input</span> <span class="nx">type</span><span class="o">=</span><span class="s2">&quot;text&quot;</span> <span class="nx">name</span><span class="o">=</span><span class="s2">&quot;title&quot;</span> <span class="nx">value</span><span class="o">=</span><span class="s2">&quot;Senza titolo&quot;</span> <span class="o">/&gt;</span><span class="p">;</span>
<span class="p">}</span>
</code></pre></div>
<p>Dal momento che questo metodo descrive la vista in ogni momento, il valore del campo di testo deve <em>sempre</em> essere <code>Senza titolo</code>.</p>
<h3><a class="anchor" name="perch-il-valore-della-textarea"></a>Perché il Valore della Textarea? <a class="hash-link" href="#perch-il-valore-della-textarea">#</a></h3>
<p>In HTML, il valore di <code>&lt;textarea&gt;</code> è solitamente impostato usando un nodo di testo figlio:</p>
<div class="highlight"><pre><code class="language-html" data-lang="html"> <span class="c">&lt;!-- antipattern: NON FARLO! --&gt;</span>
<span class="nt">&lt;textarea</span> <span class="na">name=</span><span class="s">&quot;description&quot;</span><span class="nt">&gt;</span>Questa è la descrizione.<span class="nt">&lt;/textarea&gt;</span>
</code></pre></div>
<p>Per l&#39;HTML, questo approccio permette agli sviluppatori di fornire facilmente valori su più righe. Tuttavia, dal momento che React è JavaScript, non abbiamo limitazioni sulle stringhe e possiamo usare <code>\n</code> se desideriamo andare a capo. In un mondo in cui abbiamo <code>value</code> e <code>defaultValue</code>, il ruolo giocato dal nodo figlio è ambiguo. Per questa ragione, non dovresti utilizzare il nodo figlio quando imposti il valore delle <code>&lt;textarea&gt;</code>:</p>
<div class="highlight"><pre><code class="language-javascript" data-lang="javascript"> <span class="o">&lt;</span><span class="nx">textarea</span> <span class="nx">name</span><span class="o">=</span><span class="s2">&quot;description&quot;</span> <span class="nx">value</span><span class="o">=</span><span class="s2">&quot;Questa è la descrizione.&quot;</span> <span class="o">/&gt;</span>
</code></pre></div>
<p>Se tuttavia decidi di <em>usare</em> il nodo di testo figlio, questo si comporterà come <code>defaultValue</code>.</p>
<h3><a class="anchor" name="perch-il-value-di-select"></a>Perché il Value di Select? <a class="hash-link" href="#perch-il-value-di-select">#</a></h3>
<p>L&#39;elemento <code>&lt;option&gt;</code> selezionato in un elemento HTML <code>&lt;select&gt;</code> è normalmente specificato attraverso l&#39;attributo <code>selected</code> dell&#39;opzione stessa. In React, allo scopo di rendere i componenti più semplici da manipolare, viene invece adottato il formato seguente:</p>
<div class="highlight"><pre><code class="language-javascript" data-lang="javascript"> <span class="o">&lt;</span><span class="nx">select</span> <span class="nx">value</span><span class="o">=</span><span class="s2">&quot;B&quot;</span><span class="o">&gt;</span>
<span class="o">&lt;</span><span class="nx">option</span> <span class="nx">value</span><span class="o">=</span><span class="s2">&quot;A&quot;</span><span class="o">&gt;</span><span class="nx">Arancia</span><span class="o">&lt;</span><span class="err">/option&gt;</span>
<span class="o">&lt;</span><span class="nx">option</span> <span class="nx">value</span><span class="o">=</span><span class="s2">&quot;B&quot;</span><span class="o">&gt;</span><span class="nx">Banana</span><span class="o">&lt;</span><span class="err">/option&gt;</span>
<span class="o">&lt;</span><span class="nx">option</span> <span class="nx">value</span><span class="o">=</span><span class="s2">&quot;C&quot;</span><span class="o">&gt;</span><span class="nx">Ciliegia</span><span class="o">&lt;</span><span class="err">/option&gt;</span>
<span class="o">&lt;</span><span class="err">/select&gt;</span>
</code></pre></div>
<p>Per creare un componente non controllato, viene invece usato <code>defaultValue</code>.</p>
<blockquote>
<p>Nota:</p>
<p>Puoi passare un array come valore dell&#39;attributo <code>value</code>, se desideri selezionare più opzioni in un tag <code>select</code> a scelta multipla: <code>&lt;select multiple={true} value={[&#39;B&#39;, &#39;C&#39;]}&gt;</code>.</p>
</blockquote>
<div class="docs-prevnext">
<a class="docs-prev" href="/react/docs/transferring-props-it-IT.html">&larr; Prev</a>
<a class="docs-next" href="/react/docs/working-with-the-browser-it-IT.html">Next &rarr;</a>
</div>
</div>
</section>
<footer class="wrap">
<div class="left">
A Facebook &amp; Instagram collaboration.<br>
<a href="/react/acknowledgements.html">Acknowledgements</a>
</div>
<div class="right">
&copy; 2013&ndash;2016 Facebook Inc.<br>
Documentation licensed under <a href="https://creativecommons.org/licenses/by/4.0/">CC BY 4.0</a>.
</div>
</footer>
</div>
<div id="fb-root"></div>
<script>
(function(i,s,o,g,r,a,m){i['GoogleAnalyticsObject']=r;i[r]=i[r]||function(){
(i[r].q=i[r].q||[]).push(arguments)},i[r].l=1*new Date();a=s.createElement(o),
m=s.getElementsByTagName(o)[0];a.async=1;a.src=g;m.parentNode.insertBefore(a,m)
})(window,document,'script','//www.google-analytics.com/analytics.js','ga');
ga('create', 'UA-41298772-1', 'facebook.github.io');
ga('send', 'pageview');
!function(d,s,id){var js,fjs=d.getElementsByTagName(s)[0];if(!d.getElementById(id)){js=d.createElement(s);js.id=id;js.src="https://platform.twitter.com/widgets.js";fjs.parentNode.insertBefore(js,fjs);}}(document,"script","twitter-wjs");
(function(d, s, id) {
var js, fjs = d.getElementsByTagName(s)[0];
if (d.getElementById(id)) return;
js = d.createElement(s); js.id = id;
js.src = "//connect.facebook.net/en_US/all.js#xfbml=1&appId=623268441017527";
fjs.parentNode.insertBefore(js, fjs);
}(document, 'script', 'facebook-jssdk'));
</script>
</body>
</html>