最新公告
  • 欢迎您光临网站无忧模板网,本站秉承服务宗旨 履行“站长”责任,销售只是起点 服务永无止境!立即加入钻石VIP
  • vue 全局插件制作

    正文概述 掘金(Friendlyjesse)   2021-01-29   444

    因为业务需求,制作了一个全局的活动弹窗,归纳一下主要用到的知识点。

    vue 全局插件制作

    制作一个组件

    由于ui组件库使用的是vant,制作起来比较简单

    /src/plugins/activityPopup/index.vue

    <template>
      <van-popup class="activity-popup" @close="onClose" v-model="show" closeable>
        <div class="wrapper" @click.stop="onClick">
          <van-image
            width="324"
            height="400"
            :src="img"
          />
        </div>
      </van-popup>
    </template>
    
    <script>
    export default {
      name: 'ActivityPopup',
      data () {
        return {
          show: true,
          img: require('./images/user.png')
        }
      }
    }
    </script>
    
    <style lang="scss" scoped>
    .activity-popup {
      background: none;
      ::v-deep .van-popup__close-icon--top-right {
        top: 0;
        right: 25px;
        color: white;
      }
    }
    </style>
    

    构造组件

    /src/plugins/activityPopup/index.js

    import vue from 'vue'
    import ActivityPopup from './index.vue'
    
    // 组件构造器,构造出一个 vue组件实例
    const ActivityPopupConstructor = vue.extend(ActivityPopup)
    
    function showActivityPopup ({show = true, img, callBack, click, close}) {
      const activityPopupDom = new ActivityPopupConstructor({
        el: document.createElement('div'),
        data () {
          return {
            show,
            img
          }
        },
        methods: {
          onClick () {
            click && (typeof click === 'function') && click()
            this.show = false
          },
          onClose () {
            document.body.removeChild(activityPopupDom.$el)
            close && (typeof close === 'function') && close()
          }
        }
      })
      document.body.appendChild(activityPopupDom.$el)
      callBack && (typeof callBack === 'function') && callBack()
    }
    
    function registryActivityPopup (Vue) { 
      Vue.prototype.$activitpopup = showActivityPopup
    }
    
    vue.use(registryActivityPopup)
    

    其中核心是 vue.extend,以下是官方解释:

    我理解为不包含components的一个vue实例,其余的option都可以在构造函数中混入且覆盖原有option

    使用

    /src/main.js

    // 全局活动弹窗
    import './plugins/activityPopup/index.js'
    

    在需要使用的地方

    this.$activitpopup({
        show: true,
        img: require('./plugins/activityPopup/images/user.png'),
        callBack: () => {
            console.log('rendered')
        },
        click: () => {
            console.log('click')
            this.$router.push({name: 'newYear2021'})
        },
        close: () => {
            console.log('close')
        }
    })
    

    值得注意的是,目前这个插件多次调用会多次产生dom,考虑到可能需要弹出不一样的东西,暂时没有处理。


    下载网 » vue 全局插件制作

    常见问题FAQ

    免费下载或者VIP会员专享资源能否直接商用?
    本站所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担。更多说明请参考 VIP介绍。
    提示下载完但解压或打开不了?
    最常见的情况是下载不完整: 可对比下载完压缩包的与网盘上的容量,若小于网盘提示的容量则是这个原因。这是浏览器下载的bug,建议用百度网盘软件或迅雷下载。若排除这种情况,可在对应资源底部留言,或 联络我们.。
    找不到素材资源介绍文章里的示例图片?
    对于PPT,KEY,Mockups,APP,网页模版等类型的素材,文章内用于介绍的图片通常并不包含在对应可供下载素材包内。这些相关商业图片需另外购买,且本站不负责(也没有办法)找到出处。 同样地一些字体文件也是这种情况,但部分素材会在素材包内有一份字体下载链接清单。
    模板不会安装或需要功能定制以及二次开发?
    请QQ联系我们

    发表评论

    还没有评论,快来抢沙发吧!

    如需帝国cms功能定制以及二次开发请联系我们

    联系作者

    请选择支付方式

    ×
    迅虎支付宝
    迅虎微信
    支付宝当面付
    余额支付
    ×
    微信扫码支付 0 元