发布:2014/7/25 15:58:22作者:管理员 来源:本站 浏览次数:1595
layer是一款口碑极佳的web弹层组件,她具备全方位的解决方案,致力于服务各个水平段的开发人员,您的页面会轻松地拥有丰富而友好的操作体验。
在与同类弹出层插件的比较中,layer总是能轻易获胜。她尽可能地在以更少的代码展现更强健的功能,且格外注重性能的提升、易用和实用性,正因如此,越来越多的开发者将媚眼投上了layer(已被447230人次关注)。layer兼容了包括IE6在内的所有主流浏览器。 她数量可观的接口,使得您可以自定义太多您需要的风格,每一种弹层模式各具特色,皆广受欢迎。当然,这种“王婆卖瓜”的陈述听起来总是有点难受,因此你需要进一步了解她是否真的如你所愿。
layer历经两年,截至到2014年7月5号,已服务于近15万家web平台,其中包括中国联通、蚂蚁短租、phpyun、中国网等知名网站,如果您有大型项目也在使用layer,您可以联系作者,以便在此展现案例,也为您的品牌推广尽一些绵薄之力。
layer提供了五种模式的层,分别为:信息框、页面层、iframe层、加载层、tips层,而layer.ext.js提供的拓展层是在这五种模式的基础上创建的。下面就此五种模式层进行大致的演示,更多功能还需要您自己去实验发现。使用组件时,请将layer整个文件夹放置您项目的任何一个目录下,请务必不要移动layer默认的文件结构,否则将无法运行。部署完后,您只需在页面引入layer.min.js即可(当然,别忘了引入jquery,必须使用jquery1.8或以上)
键: 值 | 描述 |
下表的属性都是默认值,您可在调用时按需重新配置,他们可帮助你实现各式各样的风格。如是调用: $.layer({键: 值, 键: 值, …}); | |
type: 0 |
层的类型。0:信息框(默认),1:页面层,2:iframe层,3:加载层,4:tips层。
此为重要参数,不同类型层的总开关,若为type:0则不需要配置,其它类型层在调用时必须设置type。 |
title: '信息' |
控制默认标题栏。 如不想显示标题栏,配置title: false 即可 |
maxmin: false |
是否输出窗口最小化/全屏/还原按钮。 如需要开启,设置maxmin: true 即可 此功能为layer1.8开始新增 |
offset: ['', ''] |
控制层坐标。 offset的值分别是: [纵坐标, 横坐标],默认为垂直水平居中 如果您要设定纵坐标,可以:offset:['200px', '']/td> |
area: ['310px', '130px'] |
控制层宽高。 area值分别为:[宽度, 高度] 当设置为auto时,意味着采用自适应(iframe层不能设置auto), 对于宽度,并不推荐您设置auto。 |
border: [10, 0.3, '#000'] |
控制层的边框。 border的值分别为:[边框大小, 透明度, 颜色, layer1.8之前需在此处加true] 如果您不想显示border,设置 border: [0] 即可 |
shade: [0.5, '#000'] |
控制遮罩。 值分别是:[遮罩透明度, 遮罩颜色, layer1.8之前需在此处加true] 如果不想显示遮罩,配置shade: [0]即可 |
shadeClose: false |
用来控制点击遮罩区域是否关闭层。 若开启,设为true即可 |
closeBtn: [0, true] |
控制层右上角关闭按钮。 closeBtn的值分别为: [关闭按钮的风格(支持0和1), true] 若不想显示关闭按钮,配置 closeBtn: false即可 |
time: 0 |
自动关闭等待秒数,整数值。 0表示不自动关闭,若3秒后自动关闭,type: 3即可 |
fix: true, | 用于设定层是否不随滚动条而滚动,固定在可视区域。 |
move: '.xubox_title' |
设定某个元素来实现对层的拖拽。 值为:用来拖拽的元素选择器 若不想拖拽,move: false即可 |
moveOut: false | 用于控制层是否允许被拖出可视窗口外 |
moveType: 0 |
用于配置拖拽类型(layer1.7之前版本不支持) 默认为引导式拖动层,若值设为1,则直接拖动层 |
bgcolor: '#fff' |
用于控制层的背景色 如果不想设置任何颜色,设置空字符即可。但是对于type:0的对话框层而言,始终都是白色 |
zIndex: 19891014 |
控制层堆叠顺序(即css的z-index)。整数值。 合理设置它,可以避免与其它插件的层级冲突 |
maxWidth: 400 |
最大宽度。整数值。 当area宽度设为auto时才有用。 |
fadeIn: 300, |
用于控制层渐显弹出(layer1.7之前版本不支持) 值为毫秒数 |
btns: 1, |
按钮的个数。提供了0-2的选择,设置0表示不输出按钮 |
btn: ['确定', '取消'], |
[按钮一的文本值 , 按钮二的文本值] 必须btns值大于0才有效 |
shift: '', |
用于控制动画弹出 有七种选择:左上(left-top),上(top), 右上(right-top),右下(right-bottom),下(bottom),左下(left-bottom),左('left')。 如shift:'top' 表示从上动画弹出 |
dialog: { type: 3, msg: '' } |
信息框层模式提供的私有参数。使用时,按需配置即可 type: 图标类型,提供了0-16的选择,也许有你喜欢的。 设置-1不显示图标 msg: 信息框内容,重要参数 |
page: { dom: '#id', html: '', url: '', ok: function(datas){} } |
页面层模式私有参数。 dom: 页面已存在的选择器 html: 直接传入的html字符串。 url: ajax请求地址。 ok: ajax请求完毕后执行的回调,datas是异步传递过来的值。 需要特别注意的是,dom、html、url只需设定其中一个就行,若配置html或url,你必须也配置宽高值。 |
iframe: { src: '', scrolling: 'auto' } |
iframe层模式私有参数。 src: 要打开的网址。 scrolling: 是否允许iframe出现滚动条,默认自动。允许:'yes',不允许:'no' |
loading: { type: 0 } |
加载层私有属性。 type: loading图标类型(提供了0-3的选择)。 一般配合ajax使用 |
tips : { msg: '', follow: '#id', guide: 0, isGuide: true, more: false, style: ['', ''] } |
tips提示层私有属性。 msg: 提示内容。 follow: 吸附目标选择器。 guide: 指引方向(0:上,1:右,2:下,3:左)。 isGuide: 是否显示默认三角形。 这个参数可配合msg帮助你自定义三角形icon more: 是否允许多个tips style: ['background-color:#FFF8ED; color:#000; border:1px solid #FF9900; /* 此处可用来自定义tips的css样式 */', '#FF9900']]。 数组第二个值,为三角形的颜色。 |
回调函数 | |
success: function(layero){ } |
层弹出成功后的回调函数. layero是回调传过来的当前层容器的实例,这意味着你可以对当前弹层进行dom操作 |
yes: function(index){} |
按钮一的回调函数 index为当前层的索引,主要用来回调执行后,配合layer.close(index)来关闭层 |
no: function(index){} |
按钮二的回调函数 |
close: function(index){} |
层右上角关闭按钮的点击事件触发回调函数。 |
end: function(){} |
层被彻底关闭后执行的回调函数。 |
moveEnd: function(){} |
拖拽完毕触发的回调函数 |
min: function(layero){}, full: function(layero){}, restore: function(layero){} |
分别为最小化、全屏、还原触发后的回调函数 layero是当前层容器的实例 layer1.8开始新增 |
方法名 | 描述 |
$.layer({基础参数}) |
核心接口,参数是一个对象,对象属性参见基础参数。 诸如layer.alert/layer.confirm/layer.msg/layer.tips等皆为$.layer()的二次封装。 |
layer.v | 获取layer版本号。 |
layer.alert(msg, icon, fn) |
对单按钮信息框的重新封装 参数分别为: 提示内容, 图标类型(-1到16的选择), 回调函数或标题 如:layer.alert('你好layer', 9); |
layer.confirm(msg, yes, no) |
对询问框的重新封装 参数分别为: 提示内容, 确定回调函数, 取消回调函数或标题 如: layer.confirm('确定删除吗?', function(){ //删除成功 }); |
layer.msg(msg, time, parme) |
对无标题栏信息框层的重新封装 参数分别为: 提示内容, 自动关闭秒数(默认2), 对象或回调函数或图标类型 当parme是一个对象时,您可配置{type: 图标, shade: 是否开启遮罩(默认true), rate: 弹出的动画类型,具体值见layer.shift的参数说明} 当parme是一个函数时,则将作为层消失后的end的回调 当parme是一个数字时,则将作为msg的图标类型 如: layer.msg('删除成功', 2, function(){ location.reload(); //自动关闭后可做一些刷新页面等操作 }); |
layer.load(parme, loadStype) |
对加载层的重新封装 参数分别为:加载提示语或自动关闭所需秒数, 加载风格(0-3的选择) 如果parme是一段文字,您可以这样:layer.load('加载中'); 如果parme是一个数字,则为自动关闭所需最长等待秒数(0时则不自动关闭) ,如:layer.load(3) //3秒后自动消失 |
layer.tips(html, follow, parme) |
对tips层的重新封装。 参数分别为:tips内容, 要吸引的dom对象, 对象 parme允许传这些属性{time: 自动关闭所需秒, maxWidth: 最大宽度, guide: 指引方向, style: tips样式(参加api表格一中的style属性)} 如: obj.on('click', function(){ layer.tips('这是小提示','#id'); }); |
layer.close(index) |
用于手动关闭层。 index参数为调用layer时返回的索引值。如: var index = $.layer({此处是您的配置}); //诸如 var index = layer.alert();之类的也会返回index索引 //关闭时,只要把index传给close方法即可关闭对应的层,如: layer.close(index); |
layer.closeTips() | 用于关闭tips层。 |
layer.closeAll() | 用于关闭所有层,在多层模式时也许会用到 |
layer.area(index, options) |
用于重定义指定层的宽高、坐标、z-index等。 参数分别为:层的索引, 对象 options允许传这些属性 {width:宽度, height: 高度, top: 纵坐标, left:横坐标, zIndex:z-index值}等css属性。 该方法仅针对页面层(type:1)和iframe层(type:2)有效; |
layer.title(name, index) |
用于动态改变层的标题。 参数name为标题名,index为层的索引; |
layer.autoArea(index) | 用来处理在层中宽高改变时,重新自适应层宽高。必填参数为层的索引值 |
layer.getChildFrame(selector, index) |
获取子iframe中的DOM。一般用于父窗口操作iframe页。 参数分别为:iframe页的选择器, 层索引 |
layer.getFrameIndex(window.name) |
获取当前所在iframe层的索引。 只允许在iframe页面内部调用。如在内部关闭自身: var index = parent.layer.getFrameIndex(window.name); parent.layer.close(index); |
layer.iframeAuto(index) |
用于让iframe层自适应。 index为层的索引 |
layer.iframeSrc(index, url) |
用于重置iframe层的url 参数分别为: 层的索引, url链接 |
layer.setMove() | 当拖拽元素改变时,可用此方法重新初始化拖拽。 |
layer.setTop(layerNow) |
引用此方法可开启点击使当前窗口置顶功能,只能用于用在success回调中。 layerNow参数即为success回调函数中传过来的参数,即当前layer容器。当需要时,需配置zIndex:layer.zIndex, 详见[场景实例]页面的例子:无限层中层 |
layer.min(index, options) layer.full(index, options) layer.restore(index) |
三个方法功能分别为:最小化、全屏、还原 index为层的索引,可通过var index = $.layer({})得到 options需传入层{area: [正常尺寸下的宽度, 正常尺寸下的高度], offset: [正常尺寸下的top, 正常尺寸下的left]} 如:layer.full(1, {area: ['300px', '200px', offset: ['200px', '']]}); 即可自己去控制什么地方操作全屏 |
layer.use(module, callback) |
载入一个模块,支持载入js、css。 参数分别为:css或js路径, 加载完毕回调函数 如载入一个js:layer.use('extend/layer.ext.js', function(){}); |
layer.index | 静态属性,用于获取最近一次触发的层索引值 |
layer.zIndex | 静态属性,用于获取layer容器中的最大z-index值 |
layer.path | 静态属性,获取当前layer的存放路径。 |
方法名 | 描述 |
目前拓展方法主要是指layer.ext.js提供的拓展类,您可以按照自己的需求选择引入,同样的,不需要引入css,只需要执行 layer.use('extend/layer.ext.js') 即可,关于layer.use的使用,请看集成方法的介绍; | |
layer.ext = function(){} |
首次加载layer.ext.js模块完毕的回调方法。 如果页面一加载即执行拓展层,需用到此方法。 如: layer.use('extend/layer.ext.js', function(){ layer.ext = function(){ layer.prompt(); } }) |
layer.prompt(options, yes, no); |
用于弹出一个prompt层模式 参数分别为:对象, 确定的回调函数, 取消的回调函数 options允许你配置: { top: 高度, type: 0, //支持普通文本框(0)、密码框(1)、文件框(2)、多行文本框(3), title: '标题', val: '', //表单的默认值 length: 200 //表单框可输入的最长值 }如: layer.prompt({title: '测试'}, function(val, index, elem){ //index为该层索引,elem为表单元素。 alert('得到:'+ val); })试一试 |
layer.tab(parme) |
实现弹出tab层。 parme是一个对象,它允许传入{data: [], area: 宽高, offset: 坐标} 如: layer.tab({ data:[ {title: '标题一', content:'内容一,可加html'}, {title: '标题二', content:'内容二。什么?嫌tab层太难看?噢是的,这只是个骨架。'} ], area: ['600px', '300px'] //宽度,高度 });试一试 |
layer.photos(options) |
实现图片的相册模式浏览。支持异步请求过来的json数据、支持直接弹出页面指定区域所有图片 options是一个对象,具体调用,深入了解 |
layer.photosPage(options) |
直接弹出页面指定区域所有图片以实现相册浏览。他是对layer.photos的二次封装 options同样是一个对象,具体调用,深入了解 |
© Copyright 2014 - 2024 柏港建站平台 ejk5.com. 渝ICP备16000791号-4