As students who have used the bootstrap framework know, the bootstrap's own modal frame is not flexible enough to use, it's a chicken rib.But the nakupanda open source Author encapsulates a more powerful and flexible modal box, bootstrap3-dialog.
1. Source Download
bootstrap3-dialog git download address
2. Effect Display
1.error warning box
data:image/s3,"s3://crabby-images/f80d4/f80d4c44013464260784b948dec314991d948df7" alt=""
2.confirm Confirmation Selection Box
data:image/s3,"s3://crabby-images/f2751/f2751544c9c43a9499e9a949f194d9ea356d2fcc" alt=""
3.Success prompt box
data:image/s3,"s3://crabby-images/b67a4/b67a429768c2c6d72a49d0513eac3b6feb503aac" alt=""
4.ajax Load Remote Page Popup Box
data:image/s3,"s3://crabby-images/f233c/f233c5b04f1cba675ad75887c6ff948297070bb4" alt=""
5.ajax Load Custom Page Popup Box
data:image/s3,"s3://crabby-images/08d48/08d4887ec3310f36c1583a60431a805f448b9f56" alt=""
3. Usage
The demo of bootstrap3-dialog has been described in detail, but it is a hassle for beginners, and there is a method and comment to see.However, these commonly used methods are encapsulated in a new way, so they are much simpler.
I won't talk more about introducing js and css files, just how to use them.
1. Eror warning box
//Logon box with error prompt pops up $.showErr = function(str, func) { // Call show method BootstrapDialog.show({ type : BootstrapDialog.TYPE_DANGER, title : 'error ', message : str, size : BootstrapDialog.SIZE_SMALL,//size is small, default dialog is wide buttons : [ {// Set Close Button label : 'Close', action : function(dialogItself) { dialogItself.close(); } } ], // Bring in callback method when dialog closes onhide : func }); };
Once encapsulated, you can use $.showErr("There is no fund daily today") when you need to pop up the error warning box.
(2) confirm the selection box
$.showConfirm = function(str, funcok, funcclose) { BootstrapDialog.confirm({ title : 'confirm', message : str, type : BootstrapDialog.TYPE_WARNING, // <-- Default value is // BootstrapDialog.TYPE_PRIMARY closable : true, // <-- Default value is false, click on the page content outside the dialog box to close draggable : true, // <-- Default value is false, draggable btnCancelLabel : 'cancel', // <-- Default value is 'Cancel', btnOKLabel : 'Determine', // <-- Default value is 'OK', btnOKClass : 'btn-warning', // <-- If you didn't specify it, dialog type size : BootstrapDialog.SIZE_SMALL, // Execute method when dialog closes onhide : funcclose, callback : function(result) { // result is true when the OK button is clicked if (result) { // Execution Method funcok.call(); } } }); };
Called through $.showConfirm(title, _doPost);
(3) Success prompt box
$.showSuccessTimeout = function(str, func) { BootstrapDialog.show({ type : BootstrapDialog.TYPE_SUCCESS, title : 'Success ', message : str, size : BootstrapDialog.SIZE_SMALL, buttons : [ { label : 'Determine', action : function(dialogItself) { dialogItself.close(); } } ], // Automatic shutdown within specified time onshown : function(dialogRef) { setTimeout(function() { dialogRef.close(); }, YUNM._set.timeout); }, onhide : func }); };
(4) ajax load remote page pop-up box
First, let's see how to use it.
<a href="${ctx}/common/showSendMessage" target="dialog">Click to open</a>
Yes, just this line of code!
- a label
- An href attribute points to a remote page
- target property set to dialog
However, we need to do some packaging.
First, when the page loads, we need to have the a tag execute the ajaxTodialog method.
$(function() { // dialogs if ($.fn.ajaxTodialog) { $("a[target=dialog]").ajaxTodialog(); } });
The second step encapsulates the ajaxTodialog method.
$.fn.extend({ ajaxTodialog : function() { return this.click(function(event) { var $this = $(this); YUNM.debug("ajaxTodialog" + $this.selector); var title = $this.attr("title") || $this.text(); var url=$this.attr("href"); $.ajax({ type : 'POST', url : url, cache : false, success : function(response) { ajaxDialog = BootstrapDialog.show({ message : function(dialog) { var $message = $('<div></div>'); $message.html(response);// Return the returned page as a message return $message; }, title : title, } }); event.preventDefault(); return false; }); }, });
_, ajax load custom page pop-up box
And are similar, but there are some differences. The differences are listed below.
Using this method, you need to add manipulating="1" to indicate that it is a custom page and does not use the header or footer of bootstrap dialog.
<a href="${ctx}/common/showSendMessage" target="dialog" manipulating="1">Custom page</a>
The ajaxTodialog method adds handling of manipulating=1.
if (manipulating == 1) { ajaxDialog = new BootstrapDialog({ message : function(dialog) { var $message = $('<div></div>'); $message.html(response); return $message; }, // Find the close event bound by the x number on the custom page onshown : function(dialogRef) { var $button = dialogRef.getModalContent().find('button[data-widget="remove"]'); $button.on('click', { dialogRef : dialogRef }, function(event) { event.data.dialogRef.close(); }); }, }); ajaxDialog.realize(); ajaxDialog.getModalHeader().hide();// header don't ajaxDialog.getModalFooter().hide();// Nor should footer ajaxDialog.getModalBody().css('padding', 0);// No Fill ajaxDialog.open(); }
That's it. In the next article, you'll make a preview of your mobile phone using bootstrap dialog.