easyui源码翻译1.32--Dialog(对话框窗口)
前言
扩展自$.fn.window.defaults。使用$.fn.dialog.defaults重写默认值对象。下载该插件翻译源码
该对话框是一种特殊类型的窗口,它在顶部有一个工具栏,在底部有一个按钮栏。对话框窗口右上角只有一个关闭按钮用户可以配置对话框的行为显示其他工具,如collapsible,minimizable,maximizable工具等。
源码
/**
* jQuery EasyUI 1.3.2
*
*翻译:qq 1364386878 对话框窗口
*/
(function ($) {
//包裹对话框窗口
function wrapDialog(target) {
var cp = document.createElement("div");
while (target.firstChild) {
cp.appendChild(target.firstChild);
}
target.appendChild(cp);
var contentPanel = $(cp);
contentPanel.attr("style", $(target).attr("style"));
$(target).removeAttr("style").css("overflow", "hidden");
contentPanel.panel({
border: false,
doSize: false,
bodyCls: "dialog-content"
});
return contentPanel;
};
//初始化
function init(jq) {
var options = $.data(jq, "dialog").options;
var contentPanel = $.data(jq, "dialog").contentPanel;
if (options.toolbar) {
if (typeof options.toolbar == "string") {
$(options.toolbar).addClass("dialog-toolbar").prependTo(jq);
$(options.toolbar).show();
} else {
$(jq).find("div.dialog-toolbar").remove();
var toolbar = $("<div class=\"dialog-toolbar\"><table cellspacing=\"0\" cellpadding=\"0\"><tr></tr></table></div>").prependTo(jq);
var tr = toolbar.find("tr");
for (var i = 0; i < options.toolbar.length; i++) {
var buttons = options.toolbar[i];
if (buttons == "-") {
$("<td><div class=\"dialog-tool-separator\"></div></td>").appendTo(tr);
} else {
var td = $("<td></td>").appendTo(tr);
var tool = $("<a href=\"javascript:void(0)\"></a>").appendTo(td);
tool[0].onclick = eval(buttons.handler || function () {
});
tool.linkbutton($.extend({}, buttons, { plain: true }));
}
}
}
} else {
$(jq).find("div.dialog-toolbar").remove();
}
if (options.buttons) {
if (typeof options.buttons == "string") {
$(options.buttons).addClass("dialog-button").appendTo(jq);
$(options.buttons).show();
} else {
$(jq).find("div.dialog-button").remove();
var _b = $("<div class=\"dialog-button\"></div>").appendTo(jq);
for (var i = 0; i < options.buttons.length; i++) {
var buttons = options.buttons[i];
var button = $("<a href=\"javascript:void(0)\"></a>").appendTo(_b);
if (buttons.handler) {
button[0].onclick = buttons.handler;
}
button.linkbutton(buttons);
}
}
} else {
$(jq).find("div.dialog-button").remove();
}
var href = options.href;
var content = options.content;
options.href = null;
options.content = null;
//渲染面板
contentPanel.panel({
closed: options.closed,
cache: options.cache,
href: href,
content: content,
onLoad: function () {
if (options.height == "auto") {
$(jq).window("resize");
}
options.onLoad.apply(jq, arguments);
}
});
$(jq).window($.extend({}, options, {
onOpen: function () {
if (contentPanel.panel("options").closed) {
contentPanel.panel("open");
}
if (options.onOpen) {
options.onOpen.call(jq);
}
},
onResize: function (width, height) {
var win = $(jq);
contentPanel.panel("panel").show();
contentPanel.panel("resize", {
width: win.width(),
height: (height == "auto") ? "auto" : win.height() - win.children("div.dialog-toolbar")._outerHeight() - win.children("div.dialog-button")._outerHeight()
});
if (options.onResize) {
options.onResize.call(jq, width, height);
}
}
}));
options.href = href;
options.content = content;
};
//刷新
function _refresh(jq, content) {
var contentPanel = $.data(jq, "dialog").contentPanel;
contentPanel.panel("refresh", content);
}; //实例化对话框
$.fn.dialog = function (target, parm) {
if (typeof target == "string") {
var method = $.fn.dialog.methods[target];
if (method) {
return method(this, parm);
} else {
return this.window(target, parm);
}
}
target = target || {};
return this.each(function () {
var dialog = $.data(this, "dialog");
if (dialog) {
$.extend(dialog.options, target);
} else {
$.data(this, "dialog", {
options: $.extend({},
$.fn.dialog.defaults,
$.fn.dialog.parseOptions(this), target),
contentPanel: wrapDialog(this)
});
}
init(this);
});
};
//默认方法
$.fn.dialog.methods = {
//返回属性对象
options: function (jq) {
var options = $.data(jq[0], "dialog").options;
var panelopts = jq.panel("options");
$.extend(options, {
closed: panelopts.closed,
collapsed: panelopts.collapsed,
minimized: panelopts.minimized,
maximized: panelopts.maximized
});
var contentPanel = $.data(jq[0], "dialog").contentPanel;
return options;
},
//返回外部对话框窗口对象
dialog: function (jq) {
return jq.window("window");
},
//刷新面板来装载远程数据。如果'href'属性有了新配置,它将重写旧的'href'属性
refresh: function (jq, href) {
return jq.each(function () {
_refresh(this, href);
});
}
};
//解析器
$.fn.dialog.parseOptions = function (target) {
return $.extend({}, $.fn.window.parseOptions(target),
$.parser.parseOptions(target, ["toolbar", "buttons"]));
};
//默认属性 同时继承window的
$.fn.dialog.defaults = $.extend({},
$.fn.window.defaults,
{
title: "New Dialog",//对话框窗口标题文本
collapsible: false,//对话框窗口标题文本
minimizable: false,//对话框窗口标题文本
maximizable: false,//对话框窗口标题文本
resizable: false,//定义是否可以改变对话框窗口大小
//设置对话框窗口顶部工具栏,可用值有:
//1) 一个数组,每一个工具栏中的工具属性都和linkbutton相同。
//2) 一个选择器指定工具栏。
toolbar: null,
//对话框窗口底部按钮,可用值有:
//1) 一个数组,每一个按钮的属性都和linkbutton相同。
//2) 一个选择器指定按钮栏。
buttons: null
});
})(jQuery);
示例代码
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Basic Dialog - jQuery EasyUI Demo</title>
<link rel="stylesheet" type="text/css" href="../../themes/default/easyui.css">
<link rel="stylesheet" type="text/css" href="../../themes/icon.css">
<link rel="stylesheet" type="text/css" href="../demo.css">
<script type="text/javascript" src="../../jquery-1.8.0.min.js"></script>
<script src="../../plugins2/jquery.parser.js"></script>
<script src="../../plugins2/jquery.linkbutton.js"></script>
<script src="../../plugins2/jquery.draggable.js"></script>
<script src="../../plugins2/jquery.resizable.js"></script>
<script src="../../plugins2/jquery.panel.js"></script>
<script src="../../plugins2/jquery.window.js"></script> <script src="../../plugins2/jquery.dialog.js"></script>
</head>
<body>
<h2>Basic Dialog</h2>
<div class="demo-info">
<div class="demo-tip icon-tip"></div>
<div>Click below button to open or close dialog.</div>
</div>
<div style="margin:10px 0;">
<a href="javascript:void(0)" class="easyui-linkbutton" onclick="$('#dlg').dialog('open')">Open</a>
<a href="javascript:void(0)" class="easyui-linkbutton" onclick="$('#dlg').dialog('close')">Close</a>
</div>
<div id="dlg" class="easyui-dialog" title="Basic Dialog" data-options="iconCls:'icon-save'" style="width:400px;height:200px;padding:10px">
The dialog content.
</div>
</body>
</html>
插件效果
easyui源码翻译1.32--Dialog(对话框窗口)的更多相关文章
- easyui源码翻译1.32+API翻译全篇导航 (提供下载源码)
前言 EasyUI每个组件都会有 属性.方法.事件 属性 所有的属性都定义在jQuery.fn.{plugin}.defaults里面.例如,对话框属性定义在jQuery.fn.dialog.defa ...
- easyui源码翻译1.32--Messager(消息窗口)
前言 使用$.messager.defaults重写默认值对象.下载该插件翻译源码 消息窗口提供了不同的消息框风格,包含alert(警告框), confirm(确认框), prompt(提示框), p ...
- easyui源码翻译1.32--datagrid(数据表格)
前言 此前网上有easyui1.25的源码 应该算是比较老的版本 之后又经历了1.26 . 1.3. 1.31. 1.32 .1.33.1.34 1.33开始支持css3 算是又一个转折 但是 ...
- easyui源码翻译1.32--EasyLoader(简单加载)
前言 扩展自$.fn.datebox.defaults,使用$.fn.datetimebox.defaults重写默认值对象.下载该插件翻译源码 源码 /** * jQuery EasyUI 1.3. ...
- easyui源码翻译1.32--Tabs(选项卡)
前言 使用$.fn.tabs.defaults重写默认值对象.下载该插件翻译源码 选项卡显示一批面板.但在同一个时间只会显示一个面板.每个选项卡面板都有头标题和一些小的按钮工具菜单,包括关闭按钮和其他 ...
- easyui源码翻译1.32--Menu(菜单)
前言 使用$.fn.menu.defaults重写默认值对象.下载该插件翻译源码 菜单组件通常用于快捷菜单.他是构建其他菜单组件的必备基础组件.比如:menubutton和splitbutton.它还 ...
- easyui源码翻译1.32--Draggable(拖动)
前言 使用$.fn.draggable.defaults重写默认值对象.下载该插件翻译源码 源码 /** * jQuery EasyUI 1.3.2 * *翻译:qq 1364386878 --拖动 ...
- easyui源码翻译1.32--Droppable(放置)
前言 使用$.fn.droppable.defaults重写默认值对象.下载该插件翻译源码 源码 /** * jQuery EasyUI 1.3.2 * *翻译:lbq --放置 拉伸 */ (fun ...
- easyui源码翻译1.32--Resizable(调整大小)
前言 使用$.fn.resizable.defaults重写默认值对象 下载该插件翻译源码 源码 /** * jQuery EasyUI 1.3.2 * *翻译:qq 1364386878 Resiz ...
随机推荐
- 动态上传多个文件(asp)
CreateElements.html <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" &quo ...
- Android屏幕适配-资源文件夹命名与匹配规则
说明:本文档目的为分析android工程res目录下的资源文件夹(drawable,values,layout等)在屏幕适配方面的限定与适配方法. 1. Res下文件夹命名方式 1. 可用的命名属性 ...
- sql server中分布式查询随笔
由于业务逻辑的多样性 经常得在sql server中查询不同数据库中数据 这就产生了分布式查询的需求 现我将开发中遇到的几种查询总结如下: 1.access版本 --建立连接服务器 exec sp_a ...
- php连接Access数据库的三种方法
http://www.php100.com/html/webkaifa/PHP/PHPyingyong/2009/1115/3524.html 虽然不是一个类但先放这儿吧 最近想把一个asp的网站改成 ...
- (十一)Hibernate 高级配置
第一节:配置数据库连接池 反问数据库,需要不断的创建和释放连接,假如访问量大的话,效率比较低级,服务器消耗大: 使用数据库连接池,我们可以根据实际项目的情况,定义连接池的连接个数,从而可以实现从连接池 ...
- 处理不等高TableViewCell
课题一:如何计算Cell高度 方案一:直接法(面向对象) 想知道妹纸爱你有多深?直接去问妹纸本人吧! 嗯!Cell也是一样的,想知道cell到底有多高?直接问Cell本人就好了.直接法,就是把数据布局 ...
- attempt to write a readonly database 的解决办法
这个问题导致我的unity项目崩溃,以至于无法打开. 第一次出现这个问题是因为在Lighting窗口中build按钮下点击了clear all baked datas,导致unity强制退出,并给出上 ...
- 08_rlCoachKin自主编译,调试
为了知道参数的意思,以及为了从头建立一个项目,我从使用QTCreator来单独建立项目(当然也可以直接使用源代码中建立好的VS项目). 其实也推荐 VS2010调试 如果是用自带的VS项目,那么我们需 ...
- [翻译][MVC 5 + EF 6] 10:处理并发
原文:Handling Concurrency with the Entity Framework 6 in an ASP.NET MVC 5 Application 1.并发冲突: 当一个用户编辑一 ...
- 【HeadFirst设计模式】10.状态模式
定义: 允许对象在内部状态改变时改变它 行为,对象看起来好像修改了它的类. OO原则: 封装变化 多用组合,少用继承 针对接口编程,不针对实现编程 为交互对象之间的松耦合设计而努力 类应该对扩展开放, ...