vue-layer,在vue中的layer插件
发布于 7 年前 作者 spnt 27841 次浏览 来自 分享

layer是非常好用的前端弹窗插件,但在vue中一直感觉没有特别适合的弹窗组件,于是就自己做了一个。

vue-layer

install

npm install vue-layer

Quick Start

在程序入口添加

import Vue from 'vue';
import layer from 'vue-layer'
Vue.prototype.$layer = layer(Vue);

调用

this.$layer.alert("找不到对象!");

Demo

http://vue.zuoyan.space/#/component/layer

Attribut

{
  type: 0, //0(信息框,默认)1(页面层)2(iframe层)3(加载层)4(tips层)
  title: '信息',
  content: '',
  area: 'auto',
  offset: 'auto',
  icon: -1,
  btn: '确定',
  time: 0,
  shade: true,
  yes: '',
  cancel: '',
  tips: [0,{}],//支持上右下左四个方向,通过1-4进行方向设定,可以设定tips: [1, '#c00']
  tipsMore: false,//是否允许多个tips
  shadeClose: false,
}

Method

 layer.alert(contetn, options, yes);
 layer.confirm(content, options, yes, cancel)
 layer.msg(contetn, options, end);
layer.tips(content, follow, options);
layer.iframe({
  content: {
    content: componentName, //传递的组件对象
    parent: this,//当前的vue对象
    data:[]//props
  },
  area:['800px','600px']
});
layer.open(options);
layer.close(id);
layer.closeAll(type);

特别PS,

关于this.$layer.iframe

其实使用iframe层,除了操作方便外,主要的目的是隔离代码, 降低代码复杂度。而在vue中,组件就是功能块的基本单位了,所以vue-layer中并不存在iframe的DOM元素,这里用的都是组件。 这里的content有三个参数: 1.content 此参数为组件对象, 比如

 import editFrom from './edir-form.vue';

此处content就为editFrom即可。

  1. parent 此参数其实就是当前调用layer的vue对象, 即this即可。在editForm中可以直接使用, this.$parent来获取调用layer的vue对象,然后父子传值神马的,就很easy,当然也可以直接使用vuex,就不用this.$parent了
  2. data 此参数可认为是editForm的props,然后你懂得

结果即为:

methods:{
   eidt() {
	  this.$layer.iframe({
		content: {
		  content: editForm, //传递的组件对象
		  parent: this,//当前的vue对象
		  data:[]//props
		},
		area:['800px','600px'],
		title:"editForm"
	  });
  }
}

不足之处还望体谅, 欢迎issues, git地址

回到顶部