Déjà Vue
data:image/s3,"s3://crabby-images/8b738/8b738a22c5b5f7f13f1fa8bb4f850f7bbd9fb5ad" alt=""
Vue.js - The MVVM library you didn't know you already knew…
SwissJS 2015 Lighting Talk – Raphaël Saunier (@RaphaelSaunier)
The Problem
Most of you are already familiar with one or more of the following frameworks:
data:image/s3,"s3://crabby-images/e4a2f/e4a2f1089f0ca7431c2e2d2feb60021b2cc5b138" alt=""
data:image/s3,"s3://crabby-images/d8055/d80558a67cbd6ff3ec018dea0aebbc8ee97cc256" alt=""
data:image/s3,"s3://crabby-images/7bdcf/7bdcf803e1c4b7477215319fbaefc0163c083b7f" alt=""
data:image/s3,"s3://crabby-images/9400c/9400c484fd656bff0780e0b28d6ccb0718a14746" alt=""
data:image/s3,"s3://crabby-images/2d637/2d6378209e913c42a047df7b14b14b35a8047d1b" alt=""
Sometimes the impact on the complexity and size of the code isn’t justifiable
Large libraries are not always adequate for:
- Legacy projects
- Prototypes, hackathons
- Server-heavy applications
- Designers
So what do we do?
data:image/s3,"s3://crabby-images/fefa6/fefa608fbc115dab79d43ce578b07c676bf1b928" alt=""
data:image/s3,"s3://crabby-images/09974/0997476a73cbed4d31466600d41f6b8aa5edcea9" alt=""
$.problem() ?
There's a better way!
data:image/s3,"s3://crabby-images/878a5/878a57efe971e4bdf7eddb0840e32401f55de962" alt=""
vuejs.org
“[…] Vue.js core intends to stay as a no-frills, drop-in view layer library, and that will not change”
data:image/s3,"s3://crabby-images/ed691/ed6917009b3696a110b9e0a78e317573d310a201" alt=""
For 70KB* you get:
- An API to define reusable Components
- Data-binding & computed properties with transparent dependency tracking
- Events, with some niceties (filtering, debouncing)
- Filters
- Transitions
All of this with a familiar syntax, a comprehensive documentation, friendly error messages and
great performance!
* Minified (~22KB gzipped)
- vue-element (allows you to register real Custom Elements)
- vue-resource (interact with REST APIs)
- vuex (Flux implementation)
- vue-router
- vue-touch (Hammer.js wrapper)
- vue-loader for WebPack
- ES7/TypeScript decorators
…and there's more!
Show us some code!
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Vue.js</title>
<script src="vue.js">
</script>
</head>
<body>
<div id="selector">
<h1>{{message}}</h1>
</div>
</body>
</html>
// Define a plain JSON
// object to hold the data
var data = {
message: "Hello"
};
// Instantiate Vue on an element
new Vue({
el: "#selector",
data: data
})
// Works since getters/setters
// are now proxied
data.message = "Hi";
This looks familiar…
<div id="selector">
<input type="text"
v-model="name">
<h1 v-if="name">
{{message | uppercase}}
</h1>
</div>
new Vue({
el: "#selector",
data: {
name: ""
},
computed: {
message: function(){
return "Hello, " + name + "!";
}
}
});
Ah nice, it supports models, filters, conditionals, …
<div id="selector">
<input type="text" ng-model="name">
<h1 ng-if="name">
<%= message %>
</h1>
</div>
// I'd like delimiters that are more difficult to type
Vue.config.delimiters: ['<%=', '%>'];
// I'd like to have the performance of Backbone Views
Vue.config.async = false
// I'd like to pretend it's Angular
Vue.config.prefix = "ng-";
var Controller = Vue.extend({
$scope: this.data // (…don't do that, it's silly)
});
Configure all the things!
<ul id="selector">
<li v-repeat="person: people"
v-on="click: greet">
{{person.name}}
</li>
</ul>
var rofl = new Vue({
el: "#selector",
data: {
people: [{
name: "Bruno",
job: "Kameramann"
} /* ... */]
},
methods: {
greet: function(person){
alert(`Ich bin ${person.name},
ich bin der ${person.job}!`);
}
}
});
All the dirty things you used to be able to do in Angular are now just a bit nicer…
data:image/s3,"s3://crabby-images/32f8f/32f8fad9be7c1eedfb24e54c9aeb0335880765ef" alt=""
Visit vuejs.org/examples for more examples
Learning Resources
data:image/s3,"s3://crabby-images/1d3a6/1d3a6a08ccf33e84fe43cf130d558d42651fdb7a" alt=""
data:image/s3,"s3://crabby-images/b73a4/b73a42c87b1155e941dd23b85946200331ad30b3" alt=""
Guide
API
“The Vast World of Vue.js”
(Free Tutorial by Jeffrey Way)
laracasts.com/series/learning-vuejs
data:image/s3,"s3://crabby-images/8c941/8c941c90e6a59e2ec6f05b4a0621091df6d1aa13" alt=""
Should you go all in on Vue.js?
Probably not.
Should you use Vue.js to replace
jQuery or Backbone Views?
Probably!
vue + vue-router > jquery + backbone + underscore + rivets + marionette
JS libraries come and go, and therefore it makes
sense to invest one's time wisely.
With Vue you‘ll:
- grok the basics in a few minutes,
- become productive within an hour
- remember most of its API in a day.
Thank you!
Copy of Déjà Vue(.js)
By shengbowen
Copy of Déjà Vue(.js)
- 1,142