2021-08-09 11:34:52 +03:00
|
|
|
<link rel=stylesheet href='./style.css'>
|
|
|
|
<script src="./vue_3.1.5.js"></script>
|
|
|
|
|
2021-08-20 15:05:52 +03:00
|
|
|
<div id=root><div></div></div>
|
2021-08-09 11:34:52 +03:00
|
|
|
|
|
|
|
<script>
|
|
|
|
|
2021-08-20 15:05:52 +03:00
|
|
|
window.mountApp = element => {
|
|
|
|
const app = Vue.createApp({
|
|
|
|
template: `
|
|
|
|
<app-header :bookCount='books.length'></app-header>
|
|
|
|
<new-book @newbook='addNewBook'></new-book>
|
|
|
|
<book-list :books='books'></book-list>
|
|
|
|
<button-grid></button-grid>
|
2021-08-26 13:07:33 +03:00
|
|
|
<div ref="mountPoint"></div>
|
2021-08-20 15:05:52 +03:00
|
|
|
`,
|
2021-08-09 11:34:52 +03:00
|
|
|
|
2021-08-20 15:05:52 +03:00
|
|
|
data() {
|
|
|
|
return {
|
|
|
|
books: [
|
|
|
|
{name: 'Pride and Prejudice' },
|
|
|
|
{name: 'To Kill a Mockingbird' },
|
|
|
|
{name: 'The Great Gatsby' },
|
|
|
|
],
|
|
|
|
};
|
|
|
|
},
|
2021-08-09 11:34:52 +03:00
|
|
|
|
2021-08-20 15:05:52 +03:00
|
|
|
methods: {
|
|
|
|
addNewBook(name) {
|
|
|
|
this.books.push({name});
|
|
|
|
}
|
|
|
|
},
|
|
|
|
});
|
2021-08-09 11:34:52 +03:00
|
|
|
|
2021-08-20 15:05:52 +03:00
|
|
|
app.component('app-header', {
|
|
|
|
template: `
|
|
|
|
<h1>vuejs@${Vue.version}</h1>
|
|
|
|
<h3>Reading List: {{ bookCount }}</h3>
|
|
|
|
`,
|
|
|
|
props: [ 'bookCount' ],
|
|
|
|
});
|
2021-08-09 11:34:52 +03:00
|
|
|
|
2021-08-20 15:05:52 +03:00
|
|
|
app.component('new-book', {
|
|
|
|
data() {
|
|
|
|
return {
|
|
|
|
name: '',
|
|
|
|
}
|
|
|
|
},
|
|
|
|
template: `
|
|
|
|
<input v-model='name' @keypress.enter='onNewBook'><button @click='onNewBook'>new book</button>
|
|
|
|
`,
|
|
|
|
emits: ['newbook'],
|
|
|
|
methods: {
|
|
|
|
onNewBook() {
|
|
|
|
this.$emit('newbook', this.name);
|
|
|
|
}
|
|
|
|
},
|
|
|
|
});
|
|
|
|
app.component('book-item', {
|
|
|
|
template: `
|
|
|
|
<div>
|
|
|
|
{{ name }}
|
|
|
|
</div>
|
|
|
|
`,
|
|
|
|
props: ['name'],
|
|
|
|
});
|
2021-08-09 11:34:52 +03:00
|
|
|
|
2021-08-20 15:05:52 +03:00
|
|
|
app.component('book-list', {
|
|
|
|
props: ['books'],
|
|
|
|
template: `
|
|
|
|
<ol>
|
|
|
|
<li v-for='book in books' :key='book.name'>
|
|
|
|
<book-item :name='book.name'></book-item>
|
|
|
|
</li>
|
|
|
|
</ol>
|
|
|
|
`,
|
|
|
|
});
|
2021-08-09 11:34:52 +03:00
|
|
|
|
2021-08-20 15:05:52 +03:00
|
|
|
app.component('color-button', {
|
|
|
|
props: {
|
|
|
|
color: String,
|
|
|
|
enabled: Boolean,
|
|
|
|
nested: {
|
|
|
|
index: Number,
|
|
|
|
value: Number,
|
|
|
|
},
|
2021-08-11 03:10:14 +03:00
|
|
|
},
|
2021-08-20 15:05:52 +03:00
|
|
|
template: `
|
|
|
|
<button :disabled='enabled' :class='color'>button {{nested.index}}</button>
|
|
|
|
`,
|
|
|
|
});
|
2021-08-11 03:10:14 +03:00
|
|
|
|
2021-08-20 15:05:52 +03:00
|
|
|
app.component('button-grid', {
|
|
|
|
render() {
|
|
|
|
const buttons = [];
|
|
|
|
const ColorButton = Vue.resolveComponent('color-button');
|
|
|
|
for (let i = 0; i < 9; ++i) {
|
|
|
|
buttons.push(Vue.h(ColorButton, {
|
|
|
|
color: ['red', 'green', 'blue'][i % 3],
|
|
|
|
enabled: i % 2 === 0,
|
|
|
|
nested: {
|
|
|
|
index: i,
|
|
|
|
value: i + 0.1,
|
|
|
|
}
|
|
|
|
}, null));
|
|
|
|
};
|
|
|
|
return buttons;
|
|
|
|
}
|
|
|
|
});
|
2021-08-26 13:07:33 +03:00
|
|
|
return app.mount(element);
|
2021-08-20 15:05:52 +03:00
|
|
|
}
|
2021-08-11 03:10:14 +03:00
|
|
|
|
2021-08-26 13:07:33 +03:00
|
|
|
window.app = window.mountApp(document.querySelector('#root div'));
|
|
|
|
window.mountNestedApp = () => window.mountApp(window.app.$refs.mountPoint);
|
2021-08-09 11:34:52 +03:00
|
|
|
|
|
|
|
</script>
|