Vue Native
Build Beautiful Native Apps Using Vue.js
Presented by Gaurav Porwal
data:image/s3,"s3://crabby-images/390d2/390d203494c5550fdb65a195159b6c281eed1da8" alt=""
What is Vue.js ?
Vue.js is a Javascript Framework to develop interactive web apps or interfaces.
data:image/s3,"s3://crabby-images/f5295/f529526d2a4d0bd3643cbf8fcc14c0cb54251fcf" alt=""
-
First Release In 2014
-
Github star 95,764
data:image/s3,"s3://crabby-images/f5295/f529526d2a4d0bd3643cbf8fcc14c0cb54251fcf" alt=""
It is based on MVVM Model
data:image/s3,"s3://crabby-images/f5295/f529526d2a4d0bd3643cbf8fcc14c0cb54251fcf" alt=""
data:image/s3,"s3://crabby-images/9b538/9b538d355e4901849cd63a3aae92220c078478db" alt=""
Single File Component
data:image/s3,"s3://crabby-images/f5295/f529526d2a4d0bd3643cbf8fcc14c0cb54251fcf" alt=""
data:image/s3,"s3://crabby-images/a5ef0/a5ef0aaff55df7c32d2e50d40c7fc94bde0c0ae8" alt=""
What is React Native ?
React Native is a Javascript FrameWork to Build Native Mobile Apps
data:image/s3,"s3://crabby-images/bd810/bd8105b85a035e147780b41a483642f3e34e191c" alt=""
Finally What is Vue Native ?
data:image/s3,"s3://crabby-images/390d2/390d203494c5550fdb65a195159b6c281eed1da8" alt=""
React Native
Vue Native
Vue.js
data:image/s3,"s3://crabby-images/390d2/390d203494c5550fdb65a195159b6c281eed1da8" alt=""
Why Vue Native ?
data:image/s3,"s3://crabby-images/390d2/390d203494c5550fdb65a195159b6c281eed1da8" alt=""
Reactive System
Reactive System
data:image/s3,"s3://crabby-images/2678c/2678cb155c1e5c342e16f8aec6587a20dbcdcc70" alt=""
<template>
<view class="container">
<button
v-bind:onPress="handleBtnClickCount"
:title="btnTitle"
/>
<text
class="text-container"
>
{{btnClickCount}}
</text>
</view>
</template>
<script>
export default {
data: function() {
return {
btnTitle: "Click Me",
btnClickCount: 0
};
},
methods: {
handleBtnClickCount: function() {
this.btnClickCount = this.btnClickCount + 1;
}
}
};
</script>
Code Separation
<template>
<view class="container">
<text class="text-container">
{{textContent}}
</text>
</view>
</template>
<script>
export default {
data: function() {
return {
textContent: "Click Me"
};
}
};
</script>
<style>
.container {
background-color: white;
align-items: center;
justify-content: center;
flex: 1;
}
.text-container {
color: blue;
padding: 2;
font-size: 20;
}
</style>
-
Template
-
Script
-
Style
Global Components
<template>
<nb-content padder>
<nb-button block primary>
<nb-text>Light</nb-text>
</nb-button>
</nb-content>
</template>
<script>
import Vue from "vue-native-core";
import { VueNativeBase } from "native-base";
Vue.use(VueNativeBase);
</script>
data:image/s3,"s3://crabby-images/c329d/c329d17372fdc39172c4085817eebef0f8453e70" alt=""
Directives And Model
-
v-if
-
v-for
-
v-model
Easy To Learn
data:image/s3,"s3://crabby-images/d527a/d527a9681d1f0e4f7012f15f27be15d6fc1ec0a7" alt=""
Demo App
<template>
<view class="container">
<text class="text-color-primary">
{{msg}}
</text>
</view>
</template>
<script>
export default {
data: function() {
return {
msg: "Hello World"
}
}
}
</script>
<style>
.container {
background-color: white;
align-items: center;
justify-content: center;
flex: 1;
}
.text-color-primary {
color: blue;
}
</style>
data:image/s3,"s3://crabby-images/60342/60342828d29d6405b8b9e63c81acdb83ac03a251" alt=""
Directives And Model
v-if Directive
<template>
<view class="container">
<view class="btn-container">
<button title="show A" :on-press="() => handleBtnClick('A')"/>
<button title="show B" :on-press="() => handleBtnClick('B')"/>
<button title="show C" :on-press="() => handleBtnClick('C')"/>
</view>
<view>
<text v-if="type === 'A'">
A
</text>
<text v-else-if="type === 'B'">
B
</text>
<text v-else-if="type === 'C'">
C
</text>
<text v-else>
Not A/B/C
</text>
</view>
</view>
</template>
data:image/s3,"s3://crabby-images/69794/69794c235827304c8d997cba6b249c053a963c73" alt=""
Condition Rendering In React Native
<View class="container">
<View class="btn-container">
<Button title="show A" onPress={() => this.handleBtnClick('A')}/>
<Button title="show B" onPress={() => this.handleBtnClick('B')}/>
<Button title="show C" onPress={() => this.handleBtnClick('C')}/>
</View>
<View>
{
this.state.type === 'A'
?
<Text>
A
</Text>
:
this.state.type === 'B'
?
<Text>
B
</Text>
:
this.state.type === 'C'
?
<Text>
C
</Text>
:
<Text>
Not A/B/C
</Text>
}
</View>
</View>
v-for Directive
<template>
<view class="container">
<text
class="text-container"
v-for="todo in todos"
:key="todo.text"
>
{{ todo.text }}
</text>
</view>
</template>
<script>
export default {
data: function() {
return {
todos: [
{ text: "Learn JavaScript" },
{ text: "Learn Vue" },
{ text: "Build something awesome" }
]
};
}
};
</script>
data:image/s3,"s3://crabby-images/cf40e/cf40edf05648f9f58d3acd559201dab0256ff901" alt=""
v-model
<template>
<view class="container">
<text-input
class="text-input-container"
placeholder="Type here"
v-model="textContent"
/>
<text
class="text-container"
>
{{textContent}}
</text>
</view>
</template>
<script>
export default {
data: function() {
return {
textContent: ""
};
}
};
</script>
data:image/s3,"s3://crabby-images/7a63e/7a63effe01b43480481c677b8bedaa310b0d5fa6" alt=""
Isn't Vue Native Awesome?
data:image/s3,"s3://crabby-images/63f46/63f46b5ea8645f02a8d139e7ecc5232f7b0799b1" alt=""
Vue Native Router
Stack Navigation
<template>
<app-navigation></app-navigation>
</template>
<script>
import { StackNavigator } from "vue-native-router";
import HomeScreen from "./screens/home/index.vue";
const AppNavigation = StackNavigator(
{
Home: { screen: HomeScreen },
},
{
initialRouteName: "Home",
headerMode: "none"
}
);
export default {
components: { AppNavigation }
};
</script>
<template>
<view :style="{ marginBottom: 80 }">
<nb-button
:style="stylesObj.btnContainer"
:onPress="handleLetGoBtnPress"
>
<nb-text> Lets Go!</nb-text>
</nb-button>
</view>
</template>
<script>
export default {
props: {
navigation: {
type: Object
}
},
methods: {
handleLetGoBtnPress: function() {
this.navigation.navigate("Home");
}
}
};
</script>
Drawer Navigation
<template>
<app-navigation></app-navigation>
</template>
<script>
import { DrawerNavigator } from "vue-native-router";
import HomeScreen from "./screens/home/index.vue";
const Drawer = DrawerNavigator(
{
Home: { screen: HomeScreen },
},
{
initialRouteName: "Home",
}
);
</script>
data:image/s3,"s3://crabby-images/a36b4/a36b4d0e03d227ec54a2dd88a26a5b31af4f1f15" alt=""
Vuex
State
import Vue from "vue-native-core";
import Vuex from "vuex";
Vue.use(Vuex);
const store = new Vuex.Store({
state: {
count: 1
}
});
export default store;
Mutation
import Vue from "vue-native-core";
import Vuex from "vuex";
Vue.use(Vuex);
const store = new Vuex.Store({
state: {
count: 1
},
mutations: {
increment(state) {
// mutate state
state.count++;
}
},
});
export default store;
Action
import Vue from "vue-native-core";
import Vuex from "vuex";
Vue.use(Vuex);
const store = new Vuex.Store({
state: {
count: 1
},
mutations: {
increment(state) {
// mutate state
state.count++;
}
},
actions: {
increment(context) {
context.commit("increment");
}
}
});
export default store;
Trigger Action From UI
<template>
<view class="container">
<button
v-bind:onPress="handleBtnClickCount"
:title="btnTitle"
/>
<text
class="text-container"
>
{{btnClickCount}}
</text>
</view>
</template>
<script>
import Store from './store';
export default {
data: function() {
return {
btnTitle: "Click Me",
btnClickCount: Store.state.count
};
},
methods: {
handleBtnClickCount: function() {
Store.dispatch('increment');
}
}
};
</script>
data:image/s3,"s3://crabby-images/2678c/2678cb155c1e5c342e16f8aec6587a20dbcdcc70" alt=""
How To Get Started
Vue Native Cli
npm install -g vue-native-cli
vue-native init <projectName>
cd <projectName>
# To Run With IOS Simulator
npm run ios
# To Run With Android Simulator
npm run android
Resources
Docs
http://vue-native.io/
NativeBase KitchenApp Using Vue Native
git clone git@github.com:GeekyAnts/KitchenSink-Vue-Native.git
cd KitchenSink-Vue-Native
npm install
npm run ios
data:image/s3,"s3://crabby-images/a36b4/a36b4d0e03d227ec54a2dd88a26a5b31af4f1f15" alt=""