data:image/s3,"s3://crabby-images/d709b/d709b548bca03b767c57557d22371f267631a585" alt=""
The Founder
data:image/s3,"s3://crabby-images/08417/084174b25504b01d9371e5b77c7e34da14894ae7" alt=""
- Previously worked as a Creative Technologist at Google
- Core Dev at Meteor
- From 2016 working full-time on the Vue.JS framework
Apr. 2015: this happened
data:image/s3,"s3://crabby-images/e1dd3/e1dd33fa15d68e1a5a651a3797b9592edb3e56b5" alt=""
data:image/s3,"s3://crabby-images/536e2/536e26ef3ef5c45afe678711f13ed0252095832d" alt=""
Is the holy place between Angular and React
Why so much hype?
- Simple API
- Easy to get started with
- Combined with
vue -router can create nice SPA's
Plus the Laravel Community
Today (on Mar 7 2018)
data:image/s3,"s3://crabby-images/7520b/7520b7f7c488db185d07741065084f77b3033d84" alt=""
data:image/s3,"s3://crabby-images/50de0/50de02cb936bd355af68dcd2257d77c1decc7e83" alt=""
vs. React
vs. Angular
data:image/s3,"s3://crabby-images/89c73/89c73ee4206ce2fe8c3beff237f96abaec5fffc6" alt=""
What does the syntax looks like?
<div id="app">
<p>{{ message }}</p>
</div>
<script src="https://unpkg.com/vue"></script>
var app = new Vue({
el: '#app',
data: {
message: 'Hello Vue!'
}
})
Declarative Rendering
Declarative Rendering
if( user.likes() ) {
if( hasBlue() ) {
removeBlue();
addGrey();
} else {
removeGrey();
addBlue();
}
}
Button
"LIKE"
<div v-if="user.liked">
<blue-like></blue-like>
</div>
<div v-else>
<grey-like></grey-like>
</div>
Imperative
Declarative
Conditionals
<div id="app">
<span v-if="seen">Now you see me</span>
</div>
<script type="text/javascript">
var app = new Vue({
el: '#app',
data: {
seen: true
}
})
</script>
Loops
<div id="app">
<ol>
<li v-for="todo in todos">
{{ todo.text }}
</li>
</ol>
</div>
<script type="text/javascript">
var app = new Vue({
el: '#app',
data: {
todos: [
{ text: 'Learn JavaScript' },
{ text: 'Learn Vue' },
{ text: 'Build something awesome' }
]
}
})
</script>
Handling User Input
<div id="app">
<p>{{ message }}</p>
<button v-on:click="reverseMessage">Reverse Message</button>
</div>
<script type="text/javascript">
var app = new Vue({
el: '#app',
data: {
message: 'Hello Vue.js!'
},
methods: {
reverseMessage: function () {
this.message = this.message.split('').reverse().join('')
}
}
})
</script>
Handling User Input
<div id="app">
<p>{{ message }}</p>
<input v-model="message">
</div>
<script type="text/javascript">
var app = new Vue({
el: '#app',
data: {
message: 'Hello Vue!'
}
})
</script>
Composing with Components
data:image/s3,"s3://crabby-images/cba3b/cba3b289a8a86e34e87085fcdcb657134cd6a842" alt=""
Each component is a little Vue instance
Vue.component('todo-item', {
props: ['todo'],
template: '<li>{{ todo.text }}</li>'
})
Composing with Components
Vue.component('todo-item', {
props: ['todo'],
template: '<li>{{ todo.text }}</li>'
})
var app = new Vue({
el: '#app',
data: {
groceryList: [
{ id: 0, text: 'Vegetables' },
{ id: 1, text: 'Cheese' },
{ id: 2, text: 'Whatever else humans are supposed to eat' }
]
}
})
<ol>
<todo-item v-for="item in groceryList" v-bind:todo="item">
</todo-item>
</ol>
Build in directives
-
v-text (Updates the element’s textContent)
-
v-html (Updates the element’s innerHTML
-
v-if (Conditionally render the element)
-
v-show (Toggle’s the element’s display CSS property)
-
v-else (Denote the “else block” for v-if and v-show
-
v-for (Loop throuth an array of object)
Build in directives
-
v-on (Used for events DOM or custom)
-
v-bind (Bind html attribute)
-
v-model (Create a two-way binding on a form input element)
-
v-ref (Create ref to template element)
-
v-el (Create reference to DOM element)
-
v-pre (Dont evaluate contents)
-
v-cloak (hide element until fully parsed)
Instance Lifecycle Hooks
data:image/s3,"s3://crabby-images/76c80/76c8008a668cd3e82c9356be276991630942f975" alt=""
new Vue({
data: {
a: 1
},
created: function () {
console.log('a is: ' + this.a)
}
})
Computed Properties
<div id="example">
{{ message.split('').reverse().join('') }}
</div>
div id="example">
<p>Original message: "{{ message }}"</p>
<p>Computed reversed message: "{{ reversedMessage }}"</p>
</div>
var vm = new Vue({
el: '#example',
data: {
message: 'Hello'
},
computed: {
// a computed getter
reversedMessage: function () {
// `this` points to the vm instance
return this.message.split('').reverse().join('')
}
}
})
How is it different from...
jQuery? 🤔
Angular? (simpler, faster, less opinionated, more flexible)
React? (faster, simpler tooling and prefers HTML/CSS over Javascript for templates)
What should I choose?
-
If you work at Google: Angular
-
If you love TypeScript: Angular (or React)
-
If you love object-orientated-programming (OOP): Angular
-
If you need guidance, structure and a helping hand: Angular
-
If you work at Facebook: React
-
If you like flexibility: React
-
If you love big ecosystems: React
-
If you like choosing among dozens of packages: React
What should I choose?
-
If you love JS & the “everything-is-Javascript-approach”: React
-
If you like really clean code: Vue
-
If you want the easiest learning curve: Vue
-
If you want the most lightweight framework: Vue
-
If you want separation of concerns in one file: Vue
-
If you are working alone or have a small team: Vue (or React)
What should I choose?
-
If your app tends to get really large: Angular (or React)
-
If you want to build an app with react-native: React
-
If you want to have a lot of developers in the pool: Angular or React
THANKS
Vue Basics
By Amit Gupta
Vue Basics
- 729