search
HomeWeb Front-endJS TutorialJQuery Dialog (JS modal window, draggable DIV)_jquery

Rendering

Calling diagram

Interaction diagram


As shown in the picture above, this is basically the complete logical flow of JQueryDialog.
1. When the user clicks the "Submit" button of the modal window, the JQueryDialog.Ok() function is called. This function corresponds to the user submission event.

2. Using the OO concept, JQueryDialog.Ok() is actually a virtual function, and its logic is encapsulated in the child window ContentWindow.Ok(). I borrowed this from FCKEditor, as shown in the following code Display:
JS code

Copy code The code is as follows:

var JQueryDialog = {
/// Submit
///
Ok:function(){
var frm = $("#jd_iframe ");
if (frm[0].contentWindow.Ok()){
JqueryDialog.Close() ;
}
else{
frm[0].focus() ;
}
}
};

So each subpage from Iframe to Dialog must define the function Ok for the parent window to call, and return true or false to notify the parent window Whether the Dialog is closed.
3. ContentWindow usually contains server-side processing logic, which requires interaction with the server through POST. Because ContentWindow itself does not contain a "Submit" button, so if you want to POST, you must do it yourself in ContentWindow.Ok() Write submit().
4. Finally, the server-side logic execution is completed and control needs to be returned to Dialog. So I encapsulated JQueryDialog.SubmitCompleted(), which contains three parameters for Dialog to perform final logical processing: whether to pop up a message and its content, whether to close the Dialog, and whether to refresh the parent window. This function also benefits from FCKEditor, as shown below:

JS code
Copy code The code is as follows:

var JQueryDialog = {
/// Submission completed
/// Pop-up prompt content, value Do not pop up if empty
/// Whether to close the dialog box
/// Whether to refresh the page (valid when closing the dialog box is true)
SubmitCompleted:function(alertMsg, isCloseDialog, isRefreshPage){
if($.trim(alertMsg).length > 0 ){
alert(alertMsg);
}
if(isCloseDialog){
JqueryDialog.Close();
if(isRefreshPage){
window.location.href = window.location.href ;
}
}
}
};


5. The result response is presented to the user.



Development Log
There are a lot of JS modal windows on the Internet. After referencing some, I finally decided to include this in many of my "original projects" One of them, after all, windows are still used very frequently in WEB development. It can also be seen from the version release log that this thing has been tinkered with for a while. It is basically still an initial version, but I will continue to improve it. In the process, I had the opportunity to learn JQuery, Fckeditor and other large-scale JS. The framework of the project has brought a lot of benefits; at the same time, I have once again experienced the pain of multi-browser compatibility and debugging of JS, but why not? Have fun doing it.
Talk about the implementation of the project: first based on floating DIV. Then iframe sub-pages. I think using iframe is the most convenient for both users and developers. The content of the modal window is the content of the sub-page. The switching of the modal window is the switching of the sub-page. Pass in the URL of different sub-pages. The address opens a modal window with different content. After confirming the framework structure, there are finally some processing details, such as the relationship between the events of the subpage and the closing of the modal window. I got great help from FCKEditor and referred to its implementation. You can view the detailed code in the DEMO; for Multi-browser compatibility encapsulates some common DOM methods; adds some custom configurations, such as border color and background color. At the same time, taking into account convenience and ease of use, all CSS is used to achieve effects, and no images are used in the project.
OK, as mentioned before, this is a relatively basic version. I will continue to improve it in the future. Everyone is welcome to use it and make valuable suggestions. (Wu Jian, 2009-06-01)
---------------------------------------- ------------------
I recently worked on a project, mainly based on the client, JQuery JSON, and wrote nearly four thousand lines of JS code. Although the project was handed over before it was completed, I began to have a good impression of JQuery and couldn't put it down, so I decided to officially rename the project JQueryDialog.
This update completely bases the code on the JQuery framework and applies namespaces to make JS look a little OO. At the same time, the client ID is modified and the jd_ prefix is ​​added to avoid conflicts. Drag and drop are modified. The core function of Drag supports multiple browsers. Finally, an example of interaction between the client and the server is added to the DEMO. Everyone is welcome to download and use it. (Wu Jian, 2009-11-05)
---------------------------------------- ------------------
I always felt that dragging was not smooth enough, so I decided to completely solve this problem. After checking a lot of information these days, I finally found the problem: Because iframe is used, when the mouse moves to the iframe, the mousemove event is lost. You can try the DEMO. After modification, the drag and drop is now completely smooth. And I also separated a DragAndDrop class specifically to implement drag and drop. . I have to thank FCKEditor again for its source code and absorb a lot of its essence. I read the news a few days ago that FCKEditor restructured the code and launched the MAC style CKEditor. I have been studying FCK and I believe I will write an article on FCKEditor in a while. Source code analysis articles.
OK, version 2.0.1 mainly optimizes core drag and drop, fixes bugs such as Dialog location and Mouse style, adds custom style configuration items, and optimizes JQuery's cache. (Wu Jian, 2009-12-13)
---------------------------------------- ------------------
Upgraded JQuery to 1.4 and fixed two bugs in event registration. (Wu Jian, 2010-01-18)
---------------------------------------- ------------------
Added internal extensions to the Open method and fixed some display bugs under IE6. (Wu Jian, 2010-02-03)

Version Release

JS Code
/***************************************************** ***********************
[Author]
Wu Jian http://wu-jian.cnblogs.com/
[Version Update]
2009-06-01: Version 1.0.1 released.
2009-07-05: Version 1.0.2, updated with some obvious bugs, fully supports IE series browsers.
2009-08-15: Version 1.0.3, encapsulates the standard DOM, is compatible with multiple browsers, beautifies the style, and adds shadow effects.
2009-11-05: Version 2.0.0, based on JQuery's new encapsulation, applies JS namespace to avoid client id conflicts.
The project was officially renamed JQuery Dialog, the core implementation of drag and drop was optimized, and it fully supports cross-browser.
2009-12-14: Version 2.0.1, optimized the core drag and drop algorithm and separated the DragAndDrop class.
Fixed the bug that caused Dialog to pause when the mouse was dragged too fast.
Fixed the bug in positioning when the Dialog is wider or taller than the page.
Fixed the bug of inaccurate mouse style and drag control area.
Added configuration items, JQuery cache optimization.
2010-01-18: Version 2.0.2, JQuery upgraded to 1.4.
2010-02-03: Version 2.0.3, adds internal extensions to the Open() method, and fixes some display bugs under IE6.
**************************************************** ********************************/
DEMO http://demo. jb51.net/js/jquery_dialog/default.html
Click to download
Statement
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
jquery实现多少秒后隐藏图片jquery实现多少秒后隐藏图片Apr 20, 2022 pm 05:33 PM

实现方法:1、用“$("img").delay(毫秒数).fadeOut()”语句,delay()设置延迟秒数;2、用“setTimeout(function(){ $("img").hide(); },毫秒值);”语句,通过定时器来延迟。

axios与jquery的区别是什么axios与jquery的区别是什么Apr 20, 2022 pm 06:18 PM

区别:1、axios是一个异步请求框架,用于封装底层的XMLHttpRequest,而jquery是一个JavaScript库,只是顺便封装了dom操作;2、axios是基于承诺对象的,可以用承诺对象中的方法,而jquery不基于承诺对象。

jquery怎么修改min-height样式jquery怎么修改min-height样式Apr 20, 2022 pm 12:19 PM

修改方法:1、用css()设置新样式,语法“$(元素).css("min-height","新值")”;2、用attr(),通过设置style属性来添加新样式,语法“$(元素).attr("style","min-height:新值")”。

jquery怎么在body中增加元素jquery怎么在body中增加元素Apr 22, 2022 am 11:13 AM

增加元素的方法:1、用append(),语法“$("body").append(新元素)”,可向body内部的末尾处增加元素;2、用prepend(),语法“$("body").prepend(新元素)”,可向body内部的开始处增加元素。

jquery中apply()方法怎么用jquery中apply()方法怎么用Apr 24, 2022 pm 05:35 PM

在jquery中,apply()方法用于改变this指向,使用另一个对象替换当前对象,是应用某一对象的一个方法,语法为“apply(thisobj,[argarray])”;参数argarray表示的是以数组的形式进行传递。

jquery怎么删除div内所有子元素jquery怎么删除div内所有子元素Apr 21, 2022 pm 07:08 PM

删除方法:1、用empty(),语法“$("div").empty();”,可删除所有子节点和内容;2、用children()和remove(),语法“$("div").children().remove();”,只删除子元素,不删除内容。

jquery怎么去掉只读属性jquery怎么去掉只读属性Apr 20, 2022 pm 07:55 PM

去掉方法:1、用“$(selector).removeAttr("readonly")”语句删除readonly属性;2、用“$(selector).attr("readonly",false)”将readonly属性的值设置为false。

jquery on()有几个参数jquery on()有几个参数Apr 21, 2022 am 11:29 AM

on()方法有4个参数:1、第一个参数不可省略,规定要从被选元素添加的一个或多个事件或命名空间;2、第二个参数可省略,规定元素的事件处理程序;3、第三个参数可省略,规定传递到函数的额外数据;4、第四个参数可省略,规定当事件发生时运行的函数。

See all articles

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

AI Hentai Generator

AI Hentai Generator

Generate AI Hentai for free.

Hot Article

Repo: How To Revive Teammates
1 months agoBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Energy Crystals Explained and What They Do (Yellow Crystal)
2 weeks agoBy尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Adventure: How To Get Giant Seeds
1 months agoBy尊渡假赌尊渡假赌尊渡假赌

Hot Tools

Atom editor mac version download

Atom editor mac version download

The most popular open source editor

MantisBT

MantisBT

Mantis is an easy-to-deploy web-based defect tracking tool designed to aid in product defect tracking. It requires PHP, MySQL and a web server. Check out our demo and hosting services.

Dreamweaver Mac version

Dreamweaver Mac version

Visual web development tools

PhpStorm Mac version

PhpStorm Mac version

The latest (2018.2.1) professional PHP integrated development tool

Safe Exam Browser

Safe Exam Browser

Safe Exam Browser is a secure browser environment for taking online exams securely. This software turns any computer into a secure workstation. It controls access to any utility and prevents students from using unauthorized resources.