@ -27,16 +27,14 @@ Nel resto di questo tutorial vengono illustrate le best practices, usando JSX e
Nella maggior parte dei casi dovresti esplicitamente passare le proprietà. Ciò assicura che venga esposto soltanto un sottoinsieme dell'API interna, del cui funzionamento si è certi.
Nella maggior parte dei casi dovresti esplicitamente passare le proprietà. Ciò assicura che venga esposto soltanto un sottoinsieme dell'API interna, del cui funzionamento si è certi.
```javascript
```javascript
var FancyCheckbox = React.createClass({
function FancyCheckbox(props) {
render: function() {
var fancyClass = props.checked ? 'FancyChecked' : 'FancyUnchecked';
var fancyClass = this.props.checked ? 'FancyChecked' : 'FancyUnchecked';
Usa sempre il pattern di destrutturazione quando trasferisci altre proprietà sconosciute in `other`.
Usa sempre il pattern di destrutturazione quando trasferisci altre proprietà sconosciute in `other`.
```javascript
```javascript
var FancyCheckbox = React.createClass({
function FancyCheckbox(props) {
render: function() {
var fancyClass = props.checked ? 'FancyChecked' : 'FancyUnchecked';
var fancyClass = this.props.checked ? 'FancyChecked' : 'FancyUnchecked';
// ANTI-PATTERN: `checked` sarebbe passato al componente interno
// ANTI-PATTERN: `checked` sarebbe passato al componente interno
return (
return (
<div{...props}className={fancyClass}/>
<div{...this.props}className={fancyClass}/>
);
);
}
}
});
```
```
## Consumare e Trasferire la Stessa Proprietà
## Consumare e Trasferire la Stessa Proprietà
@ -105,23 +99,21 @@ var FancyCheckbox = React.createClass({
Se il tuo componente desidera consumare una proprietà, ma anche passarla ad altri, puoi passarla esplicitamente mediante `checked={checked}`. Questo è preferibile a passare l'intero oggetto `this.props` dal momento che è più facile effettuarne il linting e il refactoring.
Se il tuo componente desidera consumare una proprietà, ma anche passarla ad altri, puoi passarla esplicitamente mediante `checked={checked}`. Questo è preferibile a passare l'intero oggetto `this.props` dal momento che è più facile effettuarne il linting e il refactoring.
```javascript
```javascript
var FancyCheckbox = React.createClass({
function FancyCheckbox(props) {
render: function() {
var { checked, title, ...other } = props;
var { checked, title, ...other } = this.props;
var fancyClass = checked ? 'FancyChecked' : 'FancyUnchecked';
var fancyClass = checked ? 'FancyChecked' : 'FancyUnchecked';
var fancyTitle = checked ? 'X ' + title : 'O ' + title;
var fancyTitle = checked ? 'X ' + title : 'O ' + title;
return (
return (
<label>
<label>
<input{...other}
<input{...other}
checked={checked}
checked={checked}
className={fancyClass}
className={fancyClass}
type="checkbox"
type="checkbox"
/>
/>
{fancyTitle}
{fancyTitle}
</label>
</label>
);
);
}
}
});
```
```
> NOTA:
> NOTA:
@ -150,14 +142,12 @@ z; // { a: 3, b: 4 }
Se non usi JSX, puoi usare una libreria per ottenere il medesimo pattern. Underscore supporta `_.omit` per omettere delle proprietà ed `_.extend` per copiare le proprietà in un nuovo oggetto.
Se non usi JSX, puoi usare una libreria per ottenere il medesimo pattern. Underscore supporta `_.omit` per omettere delle proprietà ed `_.extend` per copiare le proprietà in un nuovo oggetto.
```javascript
```javascript
var FancyCheckbox = React.createClass({
function FancyCheckbox(props) {
render: function() {
var checked = props.checked;
var checked = this.props.checked;
var other = _.omit(props, 'checked');
var other = _.omit(this.props, 'checked');
var fancyClass = checked ? 'FancyChecked' : 'FancyUnchecked';
var fancyClass = checked ? 'FancyChecked' : 'FancyUnchecked';
@ -27,16 +27,14 @@ The rest of this tutorial explains best practices. It uses JSX and experimental
Most of the time you should explicitly pass the properties down. This ensures that you only expose a subset of the inner API, one that you know will work.
Most of the time you should explicitly pass the properties down. This ensures that you only expose a subset of the inner API, one that you know will work.
```javascript
```javascript
var FancyCheckbox = React.createClass({
function FancyCheckbox(props) {
render: function() {
var fancyClass = props.checked ? 'FancyChecked' : 'FancyUnchecked';
var fancyClass = this.props.checked ? 'FancyChecked' : 'FancyUnchecked';
Always use the destructuring pattern when transferring unknown `other` props.
Always use the destructuring pattern when transferring unknown `other` props.
```javascript
```javascript
var FancyCheckbox = React.createClass({
function FancyCheckbox(props) {
render: function() {
var fancyClass = props.checked ? 'FancyChecked' : 'FancyUnchecked';
var fancyClass = this.props.checked ? 'FancyChecked' : 'FancyUnchecked';
// ANTI-PATTERN: `checked` would be passed down to the inner component
// ANTI-PATTERN: `checked` would be passed down to the inner component
return (
return (
<div{...props}className={fancyClass}/>
<div{...this.props}className={fancyClass}/>
);
);
}
}
});
```
```
## Consuming and Transferring the Same Prop
## Consuming and Transferring the Same Prop
If your component wants to consume a property but also wants to pass it along, you can repass it explicitly with `checked={checked}`. This is preferable to passing the full `this.props` object since it's easier to refactor and lint.
If your component wants to consume a property but also wants to pass it along, you can repass it explicitly with `checked={checked}`. This is preferable to passing the full `props` object since it's easier to refactor and lint.
```javascript
```javascript
var FancyCheckbox = React.createClass({
function FancyCheckbox(props) {
render: function() {
var { checked, title, ...other } = props;
var { checked, title, ...other } = this.props;
var fancyClass = checked ? 'FancyChecked' : 'FancyUnchecked';
var fancyClass = checked ? 'FancyChecked' : 'FancyUnchecked';
var fancyTitle = checked ? 'X ' + title : 'O ' + title;
var fancyTitle = checked ? 'X ' + title : 'O ' + title;
return (
return (
<label>
<label>
<input{...other}
<input{...other}
checked={checked}
checked={checked}
className={fancyClass}
className={fancyClass}
type="checkbox"
type="checkbox"
/>
/>
{fancyTitle}
{fancyTitle}
</label>
</label>
);
);
}
}
});
```
```
> NOTE:
> NOTE:
@ -150,14 +142,12 @@ z; // { a: 3, b: 4 }
If you don't use JSX, you can use a library to achieve the same pattern. Underscore supports `_.omit` to filter out properties and `_.extend` to copy properties onto a new object.
If you don't use JSX, you can use a library to achieve the same pattern. Underscore supports `_.omit` to filter out properties and `_.extend` to copy properties onto a new object.
```javascript
```javascript
var FancyCheckbox = React.createClass({
function FancyCheckbox(props) {
render: function() {
var checked = props.checked;
var checked = this.props.checked;
var other = _.omit(props, 'checked');
var other = _.omit(this.props, 'checked');
var fancyClass = checked ? 'FancyChecked' : 'FancyUnchecked';
var fancyClass = checked ? 'FancyChecked' : 'FancyUnchecked';