可以通过npm或bower来安装rmodal.js插件。
1 2 | npm install rmodal --save bower install rmodal --save |
在页面中引入下面的CSS和js文件。
1 2 3 | < link rel = "stylesheet" href = "css/bootstrap.min.css" /> < link rel = "stylesheet" href = "css/animate.css" type = "text/css" /> < link rel = "stylesheet" href = "src/rmodal.css" type = "text/css" /> |
使用一个下面的模板来创建一个模态对话框。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 | < div id = "modal" > < div > < div > < form method = "get" > < div > < strong >Hello Dialog</ strong > </ div > < div > Test Content </ div > < div > < button type = "submit" onclick = "modal.close();" > Close </ button > </ div > </ form > </ div > </ div > </ div > |
创建一个按钮来触发模态窗口。
1 | < a href = "#" id = "showModal" >Show modal</ a > |
最后通过下面的js代码来初始化该模态对话框插件。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 | window.onload = function () { var modal = new RModal( document.getElementById( 'modal' ) , options // 配置参数参考后面 ); document.addEventListener( 'keydown' , function (ev) { modal.keydown(ev); }, false ); document.getElementById( 'showModal' ) .addEventListener( "click" , function (ev) { ev.preventDefault(); modal.open(); }, false ); window.modal = modal; } |
rmodal.js模态对话框插件的可用配置参数有:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 | { content: 'This may be used to override all of the dialog inner html' , closeTimeout: 500 // Time to wait (ms) before afterClose() is called /** * Callbacks */ , beforeOpen: function (next) { console.log( 'I will execute right before the dialog is shown' ); next(); } , afterOpen: function () { console.log( 'I will execute just after the dialog is shown' ); } , beforeClose: function (next) { console.log( 'I will execute right before the dialog is closed' ); next(); } , afterClose: function () { console.log( 'I will execute just after the dialog is closed' ); } /** * Classes */ // Added to body element clases while the modal is opened: , bodyClass: 'modal-open' // Always added to dialog element classes: , dialogClass: 'modal-dialog modal-dialog-lg' // Added to dialog element classes after it is opened: , dialogOpenClass: 'animated fadeIn' // Added to dialog element classes before it is closed: , dialogCloseClass: 'animated fadeOut' /** * Focus */ // Set this to "false" to disable focus capture (tab/shift+tab): , focus: true // Set this to "false" to disable closing when escape key pressed: , escapeClose: true } |
content:对话框中的内容。
closeTimeout:在afterClose()方法被调用后多少秒钟关闭对话框。单位毫秒。
beforeOpen:模态窗口打开前的回调函数。
afterOpen:模态窗口打开后的回调函数。
beforeClose:模态窗口关闭前的回调函数。
afterClose:模态窗口关闭后的回调函数。
bodyClass:模态窗口body的class样式类。
dialogClass:添加到对话框上的class类。
dialogOpenClass:在模态窗口打开之后添加的class类。
dialogCloseClass:在模态窗口关闭之前添加的class类。
focus:设置为false时,不能使用tab键来获取焦点。
escapeClose:设置为false时,不能使用键盘的ESC键来关闭模态窗口。
特别申明:
本站所有资源都是由网友投稿发布,或转载各大下载站,请自行检测软件的完整性!
本站所有资源仅供学习与参考,请勿用于商业用途,否则产生的一切后果将由您自己承担!
如有侵权请联系我们删除下架,联系方式:lei1294551502@163.com