您的位置:首页 > 产品设计 > UI/UE

Vue.js 2使用中的难点举例--子组件,slot, 动态组件,事件监听

2017-04-04 17:59 1176 查看
一例打尽。。:)

<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title></title>
<link rel="stylesheet" href="demo.css" />
</head>
<body>
<div id="app">
<ul>
<li @click="currentView = 'home'" >Home</li>
<li @click="currentView = 'list'" >List</li>
<li @click="currentView = 'detail'" >Detail</li>
</ul>
<keep-alive>
<component :is="currentView"></component>
</keep-alive>
<br/>
<component :is="currentView"></component>
<br/><br/>
<my-slot>
<p slot="title"> {{title}}</p>
<div slot="content"> {{ content}} </div>
</my-slot>
<br/><br/>
<comp-a></comp-a>
<comp-b></comp-b>
</div>

</body>
<script src="http://cdn.bootcss.com/vue/2.2.4/vue.min.js"></script>
<script>
Vue.component('my-slot', {
template: '<div> \
<div class="title"> \
<slot name="title"></slot> \
</div> \
<div class="content"> \
<slot name="content"></slot> \
</div> \
</div>'
})
var bus = new Vue();
var vm = new Vue({
el: "#app",
data: {
currentView: 'home',
title: "This is a title",
content: "This is the content"
},
components: {
home: {
template: '<div> \
<p>Home</p> \
<ul> \
<li v-for="item in items"> {{ item }} </li> \
</ul> \
</div>',
data: function() {
return {
items: []
}
},
active: function(done) {
var that = this;
setTimeout(function() {
that.items = [1, 2, 3, 4, 5];
done();
}, 1000)
}
},
list: {
template: '<div>List</div>'
},
detail: {
template: '<div>Detail</div>'
},
compA: {
template: '<div> \
<input type="text" v-model="name" /> \
<button @click="create">增加</button> \
</div>',
data: function() {
return {
a: ""
}
},
methods: {
create: function() {
bus.$emit('create', {name: this.name});
this.name='';
}
}
},
compB: {
template: '<ul> \
<li v-for="item in items">{{ item.name }} </li> \
</ul>',
data: function() {
return {
items: []
}
},
mounted() {
var that = this;
bus.$on('create', function(data){
that.items.push(data);
})
}
}
}
})

</script>
</html>


内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: