vue2.0动态添加组件

方法一、
<template> <input type="text" v-model='componentName'> <button @click='add'>click me to add a component</button> </template> <script> // 引入要添加的所有组件 import component1 from './components/component1.vue' import component2 from './components/component2.vue' export default { data: function() { return { allComponents: [], componentName: '' } }, components: { // 注册所有组件 component1, component2 } methods: { add: function() { this.allComponents.push(this.componentName) // 重置输入框 this.componentName = '' }, render: function(h) { // h 为 createElement 函数,接受三个参数 // tag // data // children 具体看文档吧 return h('div',this.allComponents.map(function(componentName) { return h(componentName) })) } } } </script>
方法二、

html

  <div id="app">
    <button @click="add('a-component', 'test')">Add A</button> <button @click="add('b-component', 'test')">Add B</button> <ul> <li :is="item.component" :text="item.text" v-for="item in items"></li> </ul> </div>

javascript

var AComponent = Vue.extend({
  props: ['text'],
  template: '<li>A Component: {{ text }}</li>' }) var BComponent = Vue.extend({ props: ['text'], template: '<li>B Component: {{ text }}</li>' }) new Vue({ el: '#app', components: { 'a-component': AComponent, 'b-component': BComponent, }, data: { items: [] }, methods: { add(component, text) { this.items.push({ 'component': component, 'text': text, }) } } })

方法三、

我是写在父组件中的:

Vue.component('mycontent', {
        props: ['content'],
        data() {
            return {
                coms: [],
            }
        },
        render: function(h) {
            this.coms = []; for(var i = 0; i < this.content.length; i++) { this.coms.push(h(this.content[i], {})) } return h('div', {}, this.coms) }, });

调用的时候


    <mycontent v-bind:content="content"></mycontent> 

那么父组件中的content变化时,就会动态加载组件了

 
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值