码迷,mamicode.com
首页 > 其他好文 > 详细

使用vue的extend自定义组件开发

时间:2019-06-14 21:42:52      阅读:245      评论:0      收藏:0      [点我收藏+]

标签:div   methods   自定义组件   option   child   组件   document   app   xtend   

index.js

import Vue from ‘vue‘
import tip from ‘./tip.vue‘

const Constructor = Vue.extend(tip);

const Tip = (options={})=>{
    options.showAlert = options.fn//传来的fn给options,赋值data
    const vm = new Constructor({
        data:options
    })
    vm.$mount()
    document.body.appendChild(vm.$el)
    vm.visible = true
    return vm
}

export default Tip

  tip.vue

<template>
    <div class="tip-0">
        <div class="tip" v-show="visible" @click="tipHide()">{{message}}</div>
    </div>
</template>
<script>
export default {
    data(){
        return{
            visible:true,
            message:9999,
            showAlert:null//接收传来的fn
        }
    },
    methods:{
        tipHide(){
            this.showAlert()
            this.visible = false;
        }
    }
}
</script>

  使用

<button @click="showTip()">tip</button>

import Tip from ‘./components/tip‘

showTip(){
      Tip({
        message:2222,
         fn: () => { alert(‘关闭了‘) }
      })
    },

  

使用vue的extend自定义组件开发

标签:div   methods   自定义组件   option   child   组件   document   app   xtend   

原文地址:https://www.cnblogs.com/yiyi17/p/11025406.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!