时间:2021-05-26
缘起
我们知道在JQ中,是允许我们自定义一些插件与扩展的。定义的方式也比较简单,采用$.extend就行,那么下面就来看看在JQ中自定义一个插件的实例
JQuery如何封装一个组件
效果
我们先来看封装好的组件的效果图,这是一个根据组织机构选择人员的组件。
实现原理
我们先定义一个DbwSelectUser函数
DbwSelectUser : function (options) { var opt = $.extend({ //是否多选:true(多选),false(单选) multi:true, offset:'auto', //layerIndex:弹出窗口索引 //users数据结构:[{userId:'', userName:'', departId:'', departName:''}] onOk:function(layerIndex, users){} }, options || {}); $.LoadIframe({ title: '请选择人员', content: 'assets/js/extend/jquery/userSelect/user-select.jsp?multi=' + opt.multi, maxmin: false, area: ['840px', '500px'], resize: false, scrollbar:false, offset: opt.offset, btn: ['确定', '取消'], yes: function (index, layero) { var iframeWin = $(layero).find('iframe')[0].contentWindow; //users:[{userId:'', userName:'', departId:'', departName:''}] var users = iframeWin.getSelectedUsers(); opt.onOk(index, users); return false; } }, false);}这里的user-select.jsp就是要弹出的页面
这边调用了LoadIframe方法并传入了参数,我们来看看LoadIframe方法的实现
LoadIframe: function (options, fullScreen) { var _default = { type: 2, title: '系统窗口', content: '', area: 'auto', shadeClose: false, maxmin: true, maxWidth: 600, maxHeight: 500 }, o = $.extend(_default, options || {}), index = layui.layer.open(o); if (fullScreen) { //窗口全屏 layui.layer.full(index); } return index;}使用
$.DbwSelectUser({ //offset:弹出框显示位置(空或auto:居中,rb:右下角) offset:'rb', //选好人员后弹出框的“确定”按钮单击事件回调函数 onOk:function(layerIndex, users) { //layerIndex:弹出框layer的索引 //users数据结构:[{userId:'', userName:'', departId:'', departName:''},{....}] //以下编写接收到所选人员后自己的业务逻辑 }});可以看到其实是对layui的一个弹窗进行了封装,其中$.extend是JQuery里面扩展插件的一个方法,会用后面的同名变量替换前面的。在上诉代码中的作用是用来如果你没有传某个属性,就用默认的属性。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
Java中自定义异常详解及实例代码下面做了归纳总结,欢迎批评指正自定义异常classChushulingExceptionextendsException{pu
AndroidViewPagerIndicator详解及实例代码关于自定义View的属性零碎知识自定义View和自定义属性的知识不再此提及,这里着重说的是属性在
本文实例讲述了vue使用自定义事件的表单输入组件用法。分享给大家供大家参考,具体如下:自定义事件可以用来创建自定义的表单输入组件,使用v-model来进行数据双
自定义组件1、自定义组件被getFieldsValue包裹,会获得以下属性onChange方法,子组件调用此方法,可将值传给父组件,从而Form可拿到自定义组件
前言:前面几篇讲了自定义控件绘制原理Android自定义控件基本原理详解(一),Android自定义控件之自定义属性(二),Android自定义控件之自定义组合