mirror of
https://github.com/tenrok/vue-meta.git
synced 2026-05-19 10:09:38 +03:00
27aaf4744a
fix: webpack dev server chore: use eslint not prettier unfeat: remove support for comments (its brokenn in Vue, maybe later)
89 lines
1.6 KiB
JavaScript
89 lines
1.6 KiB
JavaScript
import Vue from 'vue'
|
|
import VueMeta from 'vue-meta'
|
|
|
|
Vue.use(VueMeta)
|
|
|
|
window.users = []
|
|
|
|
new Vue({
|
|
metaInfo () {
|
|
return {
|
|
title: 'Async Callback',
|
|
titleTemplate: '%s | Vue Meta Examples',
|
|
script: [
|
|
{
|
|
skip: this.count < 2,
|
|
vmid: 'potatoes',
|
|
src: '/user-3.js',
|
|
async: true,
|
|
callback: this.updateCounter
|
|
},
|
|
{
|
|
skip: this.count < 1,
|
|
vmid: 'vegetables',
|
|
src: '/user-2.js',
|
|
async: true,
|
|
callback: this.updateCounter
|
|
},
|
|
{
|
|
vmid: 'meat',
|
|
src: '/user-1.js',
|
|
async: true,
|
|
callback: el => this.loadCallback(el.getAttribute('data-vmid'))
|
|
},
|
|
...this.scripts
|
|
]
|
|
}
|
|
},
|
|
data () {
|
|
return {
|
|
count: 0,
|
|
scripts: [],
|
|
users: window.users
|
|
}
|
|
},
|
|
watch: {
|
|
count (val) {
|
|
if (val === 3) {
|
|
this.addScript()
|
|
}
|
|
}
|
|
},
|
|
methods: {
|
|
updateCounter () {
|
|
this.count++
|
|
},
|
|
addScript () {
|
|
this.scripts.push({
|
|
src: '/user-4.js',
|
|
callback: () => {
|
|
this.updateCounter()
|
|
}
|
|
})
|
|
},
|
|
loadCallback (vmid) {
|
|
if (vmid === 'meat') {
|
|
this.updateCounter()
|
|
}
|
|
}
|
|
},
|
|
template: `
|
|
<div id="app">
|
|
<h1>Async Callback</h1>
|
|
<p>{{ count }} scripts loaded</p>
|
|
|
|
<div>
|
|
<h2>Users</h2>
|
|
<ul>
|
|
<li
|
|
v-for="user in users"
|
|
:key="user.id"
|
|
>
|
|
<strong>{{ user.id }}</strong>: {{ user.name }}
|
|
</li>
|
|
</ul>
|
|
</div>
|
|
</div>
|
|
`
|
|
}).$mount('#app')
|