DDR爱好者之家 Design By 杰米
自己写的一款基于bootstrap风格的弹框插件,暂时只有确认框、提示框。后续功能扩展、bug修改再更新。
;(function($){ //默认参数 var PARAMS; var DEFAULTPARAMS = { width: 500, title: '提示消息', content: '', okbtn: '确定', cancelbtn: '取消', headerBackground: 'info', vbackdrop: 'static', //默认点击遮罩不会关闭modal vkeyboard: true, //按esc关闭modal confirmFn: new Object, cancelFn: new Object }; $.dialog = { confirm: function(params){ $.dialog.initParmas(params); $.dialog.Show('confirm', function(e){ if($.isFunction(PARAMS.confirmFn)){ PARAMS.confirmFn(e); } }, function(f){ if($.isFunction(PARAMS.cancelFn)){ PARAMS.cancelFn(f); } }); }, alert: function(params){ $.dialog.initParmas(params); $.dialog.Show('alert', function(e){ if($.isFunction(PARAMS.confirmFn)){ PARAMS.confirmFn(e); } }, null); }, Show: function(type, confirmCaller, cancelCaller){ var html = '<div class="modal fade" id="tipModal">' + '<div class="modal-dialog" style="width:'+PARAMS.width+'px"><div class="modal-content">' + '<div class="modal-header header_'+PARAMS.headerBackground+'">' + '<a class="close" data-dismiss="modal">×</a>' + '<h4 class="modal-title text-center">'+PARAMS.title+'</h4></div>' + '<div class="modal-body text-center body_content">'+PARAMS.content+'</div>' + '<div class="modal-footer">'; if(type=='confirm'){ html += '<button class="btn btn-default" id="btnCancel">'+PARAMS.cancelbtn+'</button>'; } html += '<button class="btn btn-primary" id="btnOk">'+PARAMS.okbtn+'</button>'; html += '</div></div></div></div>'; $('body').append(html); $('#tipModal').modal({backdrop:PARAMS.vbackdrop,keyboard:PARAMS.vkeyboard}); $.dialog.setDialogEvent(type, confirmCaller, cancelCaller); }, initParmas: function(params){ if(params!= undefined && params!= null){ PARAMS = $.extend({}, DEFAULTPARAMS, params); } }, setDialogEvent: function(type, confirmCaller, cancelCaller){ switch(type){ case 'confirm': $("#btnOk").click(function(){ $('#tipModal').modal('hide'); $('#tipModal').on('hidden.bs.modal', function(){ $('#tipModal').remove(); //要先remove modal if($.isFunction(confirmCaller)){ confirmCaller(true); } }); }); $("#btnCancel").click(function(){ $('#tipModal').modal('hide'); $('#tipModal').on('hidden.bs.modal', function(){ $('#tipModal').remove(); if($.isFunction(cancelCaller)){ cancelCaller(false); } }); }); break; case 'alert': $("#btnOk").click(function(){ $('#tipModal').modal('hide'); $('#tipModal').on('hidden.bs.modal', function(){ $('#tipModal').remove(); if($.isFunction(confirmCaller)){ confirmCaller(true); } }); }); break; }; $('#tipModal').on('hidden.bs.modal', function(){ $('#tipModal').remove(); }); $("#tipModal .close").click(function(){ $('#tipModal').on('hidden.bs.modal', function(){ $('#tipModal').remove(); }); }); //设置窗口可拖动 $('#tipModal .modal-header').Draggable($('#tipModal .modal-dialog')); } }; dialogConfirm = function(params){ $.dialog.confirm(params); }; dialogAlert = function(params){ $.dialog.alert(params); }; })(jQuery); //拖动层 ;(function($){ $.fn.extend({ Draggable: function(objMoved){ return this.each(function(){ //鼠标按下时的位置 var mouseDownPosiX, mouseDownPosiY; //obj的初始位置 var objPosiX, objPosiY; //鼠标移动的距离 var tempX, tempY; //移动的对象 var obj = $(objMoved)==undefined "left").replace("px", ""); objPosiY = obj.css("top").replace("px", ""); }).mouseup(function(){ status = false; }); $(document).mousemove(function(e){ if(status){ tempX = parseInt(e.pageX) - parseInt(mouseDownPosiX) + parseInt(objPosiX); tempY = parseInt(e.pageY) - parseInt(mouseDownPosiY) + parseInt(objPosiY); obj.css({ "left": tempX + "px", "top": tempY + "px" }); } //判断是否超出窗体 //计算出弹出层距离右边的位置 var dialogRight = parseInt($(window).width())-(parseInt(obj.css("left"))+parseInt(obj.width())); var dialogBottom = parseInt($(window).height())-(parseInt(obj.css("top"))+parseInt(obj.height())); var maxLeft = $(window).width()-obj.width(); var maxTop = $(window).height()-obj.height(); if(parseInt(obj.css("left"))<=0){ obj.css("left","0px"); } if(parseInt(obj.css("top"))<=0){ obj.css("top","0px"); } if(dialogRight<=0){ obj.css("left",maxLeft+'px'); } if(dialogBottom<=0){ obj.css("top", maxTop+'px'); } }).mouseup(function(){ status = false; }).mouseleave(function(){ status = false; }); }); } }); })(jQuery)
html页面中调用:
<body> <div class="box"> <button class="btn btn-default" id="btn_confirm">确认框</button> <button class="btn btn-default" id="btn_cancel">提示框</button> </div> </body> <script src="/UploadFiles/2021-04-02/jquery.min.js">感觉写的不是很好,后面修改了或者扩展了功能再更新。源码会上传到文件。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
DDR爱好者之家 Design By 杰米
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
DDR爱好者之家 Design By 杰米
暂无评论...
P70系列延期,华为新旗舰将在下月发布
3月20日消息,近期博主@数码闲聊站 透露,原定三月份发布的华为新旗舰P70系列延期发布,预计4月份上市。
而博主@定焦数码 爆料,华为的P70系列在定位上已经超过了Mate60,成为了重要的旗舰系列之一。它肩负着重返影像领域顶尖的使命。那么这次P70会带来哪些令人惊艳的创新呢?
根据目前爆料的消息来看,华为P70系列将推出三个版本,其中P70和P70 Pro采用了三角形的摄像头模组设计,而P70 Art则采用了与上一代P60 Art相似的不规则形状设计。这样的外观是否好看见仁见智,但辨识度绝对拉满。
更新日志
2024年11月28日
2024年11月28日
- 凤飞飞《我们的主题曲》飞跃制作[正版原抓WAV+CUE]
- 刘嘉亮《亮情歌2》[WAV+CUE][1G]
- 红馆40·谭咏麟《歌者恋歌浓情30年演唱会》3CD[低速原抓WAV+CUE][1.8G]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[320K/MP3][193.25MB]
- 【轻音乐】曼托凡尼乐团《精选辑》2CD.1998[FLAC+CUE整轨]
- 邝美云《心中有爱》1989年香港DMIJP版1MTO东芝首版[WAV+CUE]
- 群星《情叹-发烧女声DSD》天籁女声发烧碟[WAV+CUE]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[FLAC/分轨][748.03MB]
- 理想混蛋《Origin Sessions》[320K/MP3][37.47MB]
- 公馆青少年《我其实一点都不酷》[320K/MP3][78.78MB]
- 群星《情叹-发烧男声DSD》最值得珍藏的完美男声[WAV+CUE]
- 群星《国韵飘香·贵妃醉酒HQCD黑胶王》2CD[WAV]
- 卫兰《DAUGHTER》【低速原抓WAV+CUE】
- 公馆青少年《我其实一点都不酷》[FLAC/分轨][398.22MB]
- ZWEI《迟暮的花 (Explicit)》[320K/MP3][57.16MB]