2017-10-07 539 views
0

在我的vue.js應用程序中,我需要在模態中顯示自定義數據。我使用vue-js-modal能夠從我的應用程序內的任意位置顯示一個模式:https://www.npmjs.com/package/vue-js-modal使用vue-js-modal,我如何訪問傳遞給模態的數據?

我創建了一個非常簡單的自定義模式的模板來嘗試一下,叫ItemModal.vue

<template> 
    <modal name="item-modal"> 
     <b>{{item.name}}</b> 
    </modal> 
</template> 
<script> 
    export default { 
     name: 'item-modal', 
     props: [ 'item' ] 
    } 
</script> 

,我能夠成功地把它從我的ItemList.vue組件內部:

<template> 
    <div id="content"> 
     <item-modal></item-modal> 
     <li v-for="item in items"> 
      <a v-on:click="showModal(item)"> 
       <span>{{item.name}}</span> 
      </a> 
     </li> 
    </div> 
</template> 
<script> 
    import ItemModal from './ItemModal.vue'; 
    import Items from '@/api/items'; 

    export default { 
     name: 'items', 
     asyncComputed: { 
      items: { 
       async get() { 
        const items = await Items.getAll(); 
        return items.data; 
       }, 
       default: [] 
      } 
     }, 
     methods: { 
      showModal(item) { 
       this.$modal.show('item-modal', { item: item }); 
      } 
     }, 
     components: { 
      ItemModal 
     } 
    } 
</script> 

然而,模態出現空。

我在ItemModal.vue中錯過了什麼,能夠使用我在showModal函數中傳遞給它的數據?

+0

建議你閱讀了關於插槽。 https://vuejs.org/v2/guide/components.html#Content-Distribution-with-Slots – Bert

回答

0

你應該註冊插件,在項目的main.js文件,以這樣的方式

import VModal from 'vue-js-modal' 
Vue.use(VModal) 

然後你就可以調用顯示功能在任何地方你的項目:

this.$modal.show('the-name-you-asigned-in-your-modal'); 

如果你需要傳遞PARAMS的模式,你可以很容易得到他們在beforeOpen事件處理程序:

//In the template  
<modal name="hello-world" @before-open="beforeOpen"/> 


methods: { 
    beforeOpen (event) { 
    console.log(event.params.foo); 
    } 
} 

我知道你非常接近它的工作,所以我提供給你一個工作示例,以便您可以將其作爲參考:

1-將插件包含在main.js文件中。

// The Vue build version to load with the `import` command 
// (runtime-only or standalone) has been set in webpack.base.conf with an alias. 
import Vue from 'vue' 
import App from './App' 

import VModal from 'vue-js-modal' 

Vue.config.productionTip = false 
Vue.use(VModal) 

/* eslint-disable no-new */ 
new Vue({ 
    el: '#app', 
    template: '<App/>', 
    components: { App } 
}) 

2 - 創建一個包含模組件(我們稱之爲Modal.vue

<template> 
    <modal name="hello-world" @before-open="beforeOpen"> 
    <div class="wrapper"> 
     <p>{{ itemToShow }}</p> 
    </div> 
    </modal> 
</template> 

<script> 
    export default { 
    name: 'HelloWorld', 

    data: function() { 
     return { 
      item: '' 
     } 
    }, 

    computed: { 
     itemToShow: function() { 
     return this.item 
     } 
    }, 

    methods: { 
     beforeOpen (event) { 
     this.item = event.params.item; 
     } 
    } 
    } 
</script> 

<style scoped> 
    .wrapper { 
    height: 100%; 
    width: 100%; 
    background-color: black; 
    } 
</style> 

3-顯示的模態分量

<template> 
    <div id="app"> 
    <img src="./assets/logo.png"> 
    <Modal /> 
    <button @click="onClick"> 
     CLICK HERE! 
    </button> 
    </div> 
</template> 

<script> 
    import Modal from './components/Modal' 

    export default { 
    name: 'app', 
    components: { 
     Modal: Modal 
    }, 
    methods: { 
     onClick() { 
     this.$modal.show('hello-world', {item: 'Hello world'}); 
     } 
    } 
    } 
</script> 

<style> 
    #app { 
    font-family: 'Avenir', Helvetica, Arial, sans-serif; 
    -webkit-font-smoothing: antialiased; 
    -moz-osx-font-smoothing: grayscale; 
    text-align: center; 
    color: #2c3e50; 
    margin-top: 60px; 
    } 
</style> 
相關問題