Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

20 guideextras #82

Closed
wants to merge 15 commits into from
Closed
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
27 changes: 14 additions & 13 deletions src/guide/extras/animation.md
Original file line number Diff line number Diff line change
Expand Up @@ -5,13 +5,13 @@ import Colors from './demos/Colors.vue'
import AnimateWatcher from './demos/AnimateWatcher.vue'
</script>

# Animation Techniques {#animation-techniques}
# Tecniche di animazione {#animation-techniques}

Vue provides the [`<Transition>`](/guide/built-ins/transition) and [`<TransitionGroup>`](/guide/built-ins/transition-group) components for handling enter / leave and list transitions. However, there are many other ways of using animations on the web, even in a Vue application. Here we will discuss a few additional techniques.
Vue mette a disposizione i componenti [`<Transition>`](/guide/built-ins/transition) e [`<TransitionGroup>`](/guide/built-ins/transition-group) per gestire le transizioni di ingresso/uscita e di elenchi di elementi. Tuttavia, esistono molti altri modi per utilizzare le animazioni sul Web, anche in un'applicazione Vue. Qui discuteremo alcune tecniche aggiuntive.

## Class-based Animations {#class-based-animations}
## Animazioni basate su Classi {#class-based-animations}

For elements that are not entering / leaving the DOM, we can trigger animations by dynamically adding a CSS class:
Per gli elementi che non devono entrare o uscire dal DOM, possiamo attivare animazioni aggiungendo dinamicamente una classe CSS:

<div class="composition-api">

Expand Down Expand Up @@ -51,8 +51,8 @@ export default {

```vue-html
<div :class="{ shake: disabled }">
<button @click="warnDisabled">Click me</button>
<span v-if="disabled">This feature is disabled!</span>
<button @click="warnDisabled">Cliccami</button>
<span v-if="disabled">Questa funzionalità è disabilitata!</span>
</div>
```

Expand Down Expand Up @@ -88,9 +88,10 @@ export default {

<DisabledButton />

## State-driven Animations {#state-driven-animations}
## Animazioni guidate dallo stato {#state-driven-animations}

Some transition effects can be applied by interpolating values, for instance by binding a style to an element while an interaction occurs. Take this example for instance:

Alcuni effetti di transizione possono essere applicati tramite una computazione di valori, ad esempio legando uno stile a un elemento mentre avviene un'interazione. Di seguito un esempio:

<div class="composition-api">

Expand Down Expand Up @@ -128,7 +129,7 @@ export default {
:style="{ backgroundColor: `hsl(${x}, 80%, 50%)` }"
class="movearea"
>
<p>Move your mouse across this div...</p>
<p>Muovi il mouse su questo div...</p>
<p>x: {{ x }}</p>
</div>
```
Expand All @@ -141,13 +142,13 @@ export default {

<Colors />

In addition to color, you can also use style bindings to animate transform, width, or height. You can even animate SVG paths using spring physics - after all, they are all attribute data bindings:
Oltre al colore, puoi anche utilizzare le associazioni di stile per animare la trasformazione, la larghezza o l'altezza di un elemento. Puoi anche animare percorsi SVG utilizzando la conformazione vettoriale (spring physics): dopo tutto, sono tutte associazioni di dati di attributi:

<ElasticHeader />

## Animating with Watchers {#animating-with-watchers}
## Animazione con gli osservatori {#animating-with-watchers}

With some creativity, we can use watchers to animate anything based on some numerical state. For example, we can animate the number itself:
Con un po' di creatività, possiamo usare gli osservatori (watchers) per animare qualsiasi cosa in base ad uno stato numerico. Ad esempio, possiamo animare il numero stesso come nell'esempio seguente:

<div class="composition-api">

Expand Down Expand Up @@ -192,7 +193,7 @@ export default {
```

```vue-html
Type a number: <input v-model.number="number" />
Scrivi un numero: <input v-model.number="number" />
<p>{{ tweened.toFixed(0) }}</p>
```

Expand Down
136 changes: 72 additions & 64 deletions src/guide/extras/composition-api-faq.md

Large diffs are not rendered by default.

2 changes: 1 addition & 1 deletion src/guide/extras/demos/Colors.vue
Original file line number Diff line number Diff line change
Expand Up @@ -14,7 +14,7 @@ function onMousemove(e) {
:style="{ backgroundColor: `hsl(${x}, 80%, 50%)` }"
class="demo movearea"
>
<p>Move your mouse across this div...</p>
<p>Muovi il mouse su questo div...</p>
<p>x: {{ x }}</p>
</div>
</template>
Expand Down
4 changes: 2 additions & 2 deletions src/guide/extras/demos/DisabledButton.vue
Original file line number Diff line number Diff line change
Expand Up @@ -14,9 +14,9 @@ function warnNotActivated() {
<template>
<div class="demo">
<div :class="{ shake: notActivated }">
<button @click="warnNotActivated">Click me</button>
<button @click="warnNotActivated">Cliccami</button>
<span v-if="notActivated" style="margin-left: 20px"
>This feature is disabled!</span
>Questa funzionalità è disabilita!</span
>
</div>
</div>
Expand Down
4 changes: 2 additions & 2 deletions src/guide/extras/demos/ElasticHeader.vue
Original file line number Diff line number Diff line change
Expand Up @@ -63,12 +63,12 @@ function stopDrag() {
<svg class="bg" width="320" height="560">
<path :d="headerPath" fill="#3F51B5"></path>
</svg>
<div class="header">Drag Me</div>
<div class="header">Trascinami</div>
<div class="content" :style="contentPosition">
<a
href="https://play.vuejs.org/#eNqlVmtv2zYU/SsXboE6mC3bSdwVmpM9MAz9sAIdsA8b5gGhRUrWKpEESTl2DP/3HZKSbbkuUKBA4Ij3ce65D15pP/hZ62TTiEE6WNjMlNqRFa7Rj0tZ1loZR3sygmWu3IgRZarWjROcDpQbVdMbeL45WvKdZHWZ2VbXHZP/LGyWMlPSOloLxoV5L8pi7eiBZrdTr6uEo9L+alhRlLKAPGeVFZ2PdQzwD6CyTWk6oh1+6dBpM2g6isNgch4jWPeCHm4u2Xxkbg2QLrvh8IYeHmm/lARg1xhJTx+moyn9fnfr//nf1/tzzMMfr/dZsj1AnCW7Azhe6J+W8jwsfp2Q7qOypSuV/ELsaMt3Xp3saNxL48yA1Vp4DFg+ojA/0i2ldH/GPqAROcOkzZWpU3oKzxVzYui5wnPS4hz09gZsydc3Us4bidqCZWiD79FQ3ERMgagiydZMFoL/qZpsLSziX4r+mf4LRmgn9ZvsTBOEATjZBjDNCvHXSeiTj8K/wadHR8lv5ZLT8MSnhUFVA5PeyHxHw5YZutCyRW2C9alJLc+jya5n8VmXZsm865MP6hEugp61pevIRUOUDjVouX8hoWsXy8uPF5ThBvtRiGKQGXVPX3OdzozdTov0hGu1QdAR8cYwTzil76e4vrkpA/+Ubt+Fe+ydQzljhotJ3ETYQTg4UWs/qDgRLXi5aQtWMWsflgPuU2OrSiwHUfFTrRoruHqW0B5H9qh1fgyC+Ko6ONdqI6CNA9b3vK4KXo0OiLElfS8h+TVdcKsEC5B9bcgW+dpNcUx1BR09l9ytccASwmkdeoDj/C2OrRPctN9oqQ962nAwz8uqguzV3W/z2S9zOCwm3rILNkG07hmFPgaOGDD3/OiDWEygvWbY7jVESq3bVT6ti1UHkPeiqtQJontaTM46jWMAIJspLTgkybHRcaxXLPtUGNVIPs5UpUxKr/I8/yGo1HZs1wwj4N8T93pLs7f4McWKYdv5F4j/S2bzm2AeKpr6ra63QRCLium87yRouskrj7cuORcyCGtmcKfgCCtijVNBqttEUyxfJIN3UhA7sXVjVpUFFBnqIUwQ56jO2JYvuDUzED3JnlsOd9NpEGJQzNgPSwahVDKirpRBY8aG8bKxKb0LCLhByaqIVTqxYSurKrxhIhulUZrwWIkciPH5ZVxKLvw7toWJjccFT9o2XqL2cjy6z2IlGOe4/rFAp8aUL0HYUoeoF6t78/U72nUEXwvnRYqFuxX153VbqYpHYEy1nySM0GA0iF8q45ppfJUoia+eEG/ZKuxykHZbE6vl9AHj5bgHzmmbTiYZl4n9tNMYwYSLzaRn2O2xweF/7cIdbA=="
target="_blank"
>Source code</a
>Codice sorgente</a
>
</div>
</div>
Expand Down
Loading