jQuery Easy UI 开发笔记

时间:2022-11-08 21:46:21

1、jQuery Easy UI主要的运行原理是通过核心的代码调用插件来实现UI效果的

2、jQuery Easy UI插件与插件之间的关系是:

一、独立式插件:

独立式插件是指:不与其他的插件具有相互的依赖关系,这些插件的用法一般相对简单

典型的代表有:pagination(分页)、searchbox(搜索框)、progressbar(进度条)、tooltip(提示框)

二、叠加式插件:

叠加式插件指的是:通过一些简单的插件去叠加而成,并且继承三大基本功能组件

科普一下:三大基本功能组件是LZ,自己定义的,指的是:draggable(拖动)、droppable(放置)、resizable(调整大小),这些跟独立式插件的不同是,这些插件往往与复杂的插件有依赖关系

帮助手册中的依赖关系:可以简单的理解为继承关系,也就是父类可以调用里面的属性和方法

例如以menubutton(菜单按钮)为例,那么之间的依赖关系如下:

jQuery Easy UI 开发笔记

menubutton的HTML代码如下:

<a href="javascript:void(0)" id="mb" class="easyui-menubutton"
data-options="menu:'#mm',iconCls:'icon-edit'">Edit</a>
<div id="mm" style="width:150px;">
<div data-options="iconCls:'icon-undo'">Undo</div>
<div data-options="iconCls:'icon-redo'">Redo</div>
<div class="menu-sep"></div>
<div>Cut</div>
<div>Copy</div>
<div>Paste</div>
<div class="menu-sep"></div>
<div data-options="iconCls:'icon-remove'">Delete</div>
<div>Select All</div>
</div>

JavaScript脚本如下:

$('#mb').menubutton({
iconCls: 'icon-edit',
menu: '#mm'
});

其中id为mm的标签可以使用menu控件的属性和方法

在mm标签下面对应的Button控件(也就是HTML代码中的div)可以使用button的属性和方法

3、jQuery Easy UI的布局

jQuery Easy UI主要的布局思想是按照讲页面风格成为东、西、南、北、中五块模块,然后根据业务需求将里面有些模块进行隐藏,固定等处理(juqery Easy UI主要适用后台管理系统的开发,因为Easy UI过于庞大所有会印象前端页面的加载速度,而且不能进行瀑布流布局响应式布局的开发)

4、validateBox(验证框)验证规则的自定义

HTML示例代码:

<input id="vv" class="easyui-validatebox" data-options="required:true,validType:'email'" />  

JS示例代码:

//判断两次输入的密码是否相同
$.extend($.fn.validatebox.defaults.rules, {
equals: {
validator: function(value,param){
return value == $(param[0]).val();
},
message: 'Field do not match.'
}
sameVal:{
        validator:function(value,param){
                return value!=param;
            },
            message:'不能与旧密码相同'
        },
});

注释:

$.extend();    jquery的拓展方法,用于对jquery进行拓展操作

equal:为自定的一个字段,在使用的时候可以看成是方法名,但是必须对其进行传参

$.fn.validatebox.defaults.rules  对validatebox控件默认的验证规则进行重写

value   当前控件的value值 相当于$(this).val()

param 传入参数的第一个位置的对象

使用方法:

在JavaScript中加入以下代码即可

$('vv').validatebox({
validType:'equals["#firstPassword"]',
});
//将id为firstPassword传给equals

如果是要匹配多个规则的话,可以讲验证的条件依次放进数组中

示例:

    $('#firstPassword').validatebox({
required:true,
validType:['equals["#firstPassword"]','sameVal["123456"]'],
});

在进行多个验证规则的匹配的时候,要注意匹配的先后顺序,

在同时匹配多个验证规则的时候,框架中默认的是匹配第一个验证规则,也就是不对第二个验证规则进行匹配

Easy UI换皮肤

easy ui中提供了几套皮肤供用户选择,具体位置是在

jQuery Easy UI 开发笔记

还可以直接从官网下载,一些新主题包,下载地址

为了将当前的主题转态保存起来,要使用jquery-cookie的JS控件,下载地址

实现换肤的逻辑

1、将所有的主题包放在同一目录下面

2、通过单击换肤按钮给指定的JS脚本传递一个值,然后获取当前主题包的CSS路径,将不同的主题包名进行替换

注意:不能将引入的主题包写死

3、然后对指定的id的标签中的href属性进行重写

这个也就是为什么要在Link标签中添加id属性的原因

4、将传入的themeName保存到cookie中

换肤的步骤

1、引入JavaScript的coookie控件

<script type="text/javascript" src="jquery-cookie.js"></script>

2、

使用C#获取cookie中保存的值

<link id="easyuiTheme" rel="stylesheet" href="
<%=
var cookie=Request.cookie['easyuiThemeName'];
if(cookie==null){
return ’default‘;
}else{
return Request.cookie['easyuiThemeName'];
}
=%>
/easyui.css" type="text/css"></link>

JS的处理脚本如下:

changeTheme = function(themeName) {
var $easyuiTheme = $('#easyuiTheme');
var url = $easyuiTheme.attr('href');
var href = url.substring(0, url.indexOf('themes')) + 'themes/' + themeName + '/easyui.css';
$easyuiTheme.attr('href', href); var $iframe = $('iframe');
if ($iframe.length > 0) {
for ( var i = 0; i < $iframe.length; i++) {
var ifr = $iframe[i];
$(ifr).contents().find('#easyuiTheme').attr('href', href);
}
} $.cookie('easyuiThemeName', themeName, {
expires : 7
});
};

主要黄色的内容是为了嵌套模块进行主题变换用的

也就是如果在页面中嵌套一个iframe标签,那么主题变换是不会影响到iframe标签里面的变换的,因为iframe标签相当于分离成两个页面,所以也要对iframe标签重复进行替换一次

Easy UI插件的修改

注释:由于Easy UI不是开源,所以不能对其进行插件的开发,但是可以对其进行修改

以ProgressBar控件为例:

$.fn.progressbar.parseOptions=function(_12){
return $.extend({},$.parser.parseOptions(_12,["width","height","text",{value:"number"}]));
};
$.fn.progressbar.defaults={width:"auto",height:22,value:0,text:"{value}%",onChange:function(_13,_14){
}};
$.fn.progressbar.parseOptions是定义控件的属性及属性传入值得类型
$.fn.progressbar.defaults是定义控件的默认值
其他的内容没有研究出来,希望有研究出来的同学一起探讨一下

jQuery Easy UI 开发笔记的更多相关文章

  1. JQuery Easy Ui dataGrid 数据表格 ---制作查询下拉菜单

    JQuery Easy Ui dataGrid 数据表格 数据表格 - DataGrid 继承$.fn.panel.defaults,使用$.fn.datagrid.defaults重载默认值.. 数 ...

  2. JQuery Easy UI 简介

    [什么是JQuery Easy UI?] jQuery EasyUI 是一组基于 jQuery 的 UI 插件集合,而 jQuery EasyUI 的目标就是帮助Web 开发者更轻松的打造出功能丰富并 ...

  3. Jquery easy UI 上中下三栏布局 分类: ASP&period;NET 2015-02-06 09&colon;19 368人阅读 评论&lpar;0&rpar; 收藏

    效果图: 源代码: <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://w ...

  4. jQuery Easy UI &lpar;适应屏幕分辨率大小&rpar;布局&lpar;Layout&rpar;

    一.jQuery Easy UI (适应屏幕分辨率大小)布局(Layout) 1.首先应用的是jquery-easyui-1.4 版本(版本不同,兼容性不同) 2.实现整个页面的布局( layout: ...

  5. jQuery Easy UI Resizable&lpar;调整大小&rpar;组件

    Resizable(调整大小)组件,easyui基础组件之中的一个.调整大小就是能够对元素能够拖着调整大小,这个组件不依赖于其它组件,使用比較简单,相关的属性.事件都 在样例中介绍了. 演示样例: & ...

  6. jQuery Easy UI Droppable&lpar;放置&rpar;组件

    Droppable(放置)组件也是一个基本组件,使用方法较简单,语法都在样例里面凝视了: 演示样例: <!DOCTYPE html> <html> <head> & ...

  7. JQuery Easy Ui (Tree树)详解(转)

    第一讲:JQuery Easy Ui到底是什么呢? 首先咱们知道JQuery是对Java Script的封装,是一个js库,主要提供的功能是选择器,属性修改和事件绑定等等.. JQuery ui是在j ...

  8. jQuery Easy UI LinkButton&lpar;button&rpar;包

    LinkButton(button)包,easyui其中一个基本组成部分 演示样例: <!DOCTYPE html> <html> <head> <title ...

  9. jQuery Easy UI Tooptip&lpar;提示框&rpar;组件

    我们都知道DOM节点的title属性.Tooptip组件就是比較强大的title,它能够*的设置自己的样式.位置以及有自己相关的触发事件. 演示样例: <!DOCTYPE html> & ...

随机推荐

  1. Spring MVC类型转换器

    类型转换器引入 为什么页面上输入"12",可以赋值给Handler方法对应的参数?这是因为框架内部帮我们做了类型转换的工作.将String转换成int 但默认类型转换器并不是可以将 ...

  2. 【codevs3945】 完美拓印

    http://codevs.cn/problem/3945/ (题目链接) 题意 给出一个诡异的图形,再给出一个歪七扭八的线,问图形上下两条边与线的匹配→_→ Solution 前后求差然后KMP,这 ...

  3. 2&period;1 LibCurl编程流程(转)

    转载地址:http://blog.chinaunix.net/u/17660/showart_1822514.html2 LibCurl编程2.1 LibCurl编程流程在基于LibCurl的程序里, ...

  4. 武汉科技大学ACM :1008&colon; A&plus;B for Input-Output Practice &lpar;VIII&rpar;

    Problem Description Your task is to calculate the sum of some integers. Input Input contains an inte ...

  5. DEV GridControl 根据单元格值改变背景色

    GridControl 根据单元格值改变背景色(需要用到CustomDrawCell事件) 方法1: private void gdvClient_CustomDrawCell(object send ...

  6. 结对编程1——四则运算-GUI

    码市链接:https://coding.net/u/hmhhh/p/hmh-homework/git/tree/master/ 201421123003 黄建英 201421123004 黄美海 题目 ...

  7. Openvpn搭建详解

    说明:公司新购进一批阿里云ESC服务器,计划只有一台有公网IP,其他都通过内网连接.那么问题来了,平时维护时,如果要通过远程工具连接其他服务器就需要先登录公网服务器(A),然后跳转到其内网其他机器上, ...

  8. 请求http页面的相关过程

    http请求从TCP建立三次握手后进行,客户端按照规定的格式向服务器发送http请求,服务器在接收到这个请求之后,首先要对其进行解析,发掘出客户端所需要的相关资源,然后经过相应的业务逻辑处理,找到这个 ...

  9. iis和tomcat(整合)

    ---恢复内容开始---   (一)   为什么要把IIS.Tomcat整合到一起?假如你遇到这种情况,你开发了一个javaweb项目要部署到服务器上,但是这个服务器上已经部署了asp.asp.net ...

  10. EF CodeFirst&lpar;三&rpar; 并发处理

    并发分为两种,一种叫做悲观并发,一种叫乐观并发. 名字挺文艺 悲观并发 悲观并发是什么呢? 就拿我们常用的代码版本控制来说. 有一个文档,A和B都要 获取这个文档并进行修改, 如果当A在读取这个文档数 ...