jQuery Easyui实现左右布局


Posted in Javascript onJanuary 26, 2016

EasyUI 简介

easyui是一种基于jQuery的用户界面插件集合。

easyui为创建现代化,互动,JavaScript应用程序,提供必要的功能。

使用easyui你不需要写很多代码,你只需要通过编写一些简单HTML标记,就可以定义用户界面。

easyui是个完美支持HTML5网页的完整框架。

easyui节省您网页开发的时间和规模。

easyui很简单但功能强大的。

在后台管理系统开发的过程中,上左右的布局是最常见的页面布局方式,现在我们来看看使用easyui这个jquery前端框架如何快速搭建一个可用的页面框架。

1.在页面中引入easyui所需的文件

<%-- 加载easyui的样式文件,bootstrap风格 --%>
<link href="${ctx }/css/themes/bootstrap/easyui.css" rel="stylesheet">
<link href="${ctx }/css/themes/icon.css" rel="stylesheet">
<%-- 加载jquery和easyui的脚本文件 --%>
<script src="${ctx }/js/jquery-easyui-../jquery.min.js"></script>
<script src="${ctx }/js/jquery-easyui-../jquery.easyui.min.js"></script>
<script src="${ctx }/js/jquery-easyui-../locale/easyui-lang-zh_CN.js"></script>

2.在页面body部分构建必要的html结构

<body>
<div id="home-layout">
<!-- 页面北部,页面标题 -->
<div data-options="region:'north'" style="height:50px;">
<!-- add your code -->
</div>
<!-- 页面西部,菜单 -->
<div data-options="region:'west',title:'菜单栏'" style="width:200px;">
<div class="home-west">
<ul id="home-west-tree"></ul>
</div>
</div>
<!-- 页面中部,主要内容 -->
<div data-options="region:'center'">
<div id="home-tabs">
<div title="首页">
<h2 style="text-align: center">欢迎登录</h2>
</div>
</div>
</div>
</div>
</body>

这里需要注意一点:easyui在使用layout布局的时候,north、south需要指定高度,west、east需要指定宽度,而center会自动适应高和宽。

3.使用js初始化easyui组件

我个人比较推荐使用js代码去初始化easyui组件,而不使用easyui标签中的data-options属性去初始化。因为对于后台开发人员来说,写js代码可能比写html标签更加熟悉,而且这样使得html代码更加简洁。

<script>
$(function(){
/*
* 初始化layout
*/
$("#home-layout").layout({
//使layout自适应容器
fit: true
});
/*
* 获取左侧菜单树,并为其节点指定单击事件
*/
$("#home-west-tree").tree({

//加载菜单的数据,必需
url: "${ctx }/pages/home-west-tree.json",
method: "get",


//是否有层次线
lines: true,


//菜单打开与关闭是否有动画效果
animate: true,


//菜单点击事件
onClick: function(node){
if(node.attributes && node.attributes.url){




 //打开内容区的tab,代码在其后
addTab({
url: "${ctx }/" + node.attributes.url,
title: node.text
});
}
}
});

/*
* 初始化内容区的tabs
*/
$("#home-tabs").tabs({
fit : true,


//tab页是否有边框
border : false
});})
</script>
<script>
/*
* 在内容区添加一个tab
*/
function addTab(params){
var t = $("#home-tabs");
var url = params.url;
var opts = {
title: params.title,
closable: true,
href: url,
fit: true,
border: false
};
//如果被选中的节点对应的tab已经存在,则选中该tab并刷新内容
//否则打开一个新的tab
if(t.tabs("exists", opts.title)){
var tab = t.tabs("select", opts.title).tabs("getSelected");
t.tabs("update", {
tab: tab,
options: opts
});
}else{
t.tabs("add", opts);
}
}
</script>

4.easyui-tree组件所需的json格式

easyui使用的传输格式为json,它对json内容的格式有比较严格的限制,所以请注意查看api

[{
"text":"区域管理",
"attributes":{
"url":"pages/consume/area/areaList.jsp"
}
},{
"text":"预约信息管理",
"children":[{
"text":"商户预约信息查询",
"attributes":{
"url":"/pages/consume/reservation/merchantReservation/merchantReservationList.jsp"
}
}]
},{
"text":"准入申请管理",
"children":[{
"text":"商户准入申请",
"state":"closed",
"children":[{
"text":"商户待处理申请",
"attributes":{
"url":"waterAply.do?method=toList&channelType=1&handleFlag=aply_wait"
}
},{
"text":"商户审批中申请",
"attributes":{
"url":"waterAply.do?method=toList&channelType=1&handleFlag=aply_current"
}
},{
"text":"商户审批通过申请",
"attributes":{
"url":"waterAply.do?method=toList&channelType=1&handleFlag=aply_pass"
}
},{
"text":"商户被拒绝申请",
"attributes":{
"url":"waterAply.do?method=toList&channelType=1&handleFlag=aply_refuse"
}
}]
}]
},{
"text":"准入审批管理",
"children":[{
"text":"商户审批管理",
"state":"closed",
"children":[{
"text":"当前任务",
"children":[{
"text":"商户当前初审任务",
"attributes":{
"url":"pages/consume/approval/merchantApproval/merchantApprovalTrial.jsp"
}
},{
"text":"商户当前复审任务",
"attributes":{
"url":"pages/consume/approval/merchantApproval/merchantApprovalRetrial.jsp"
}
}]
},{
"text":"商户已完成任务",
"attributes":{
"url":"pages/consume/approval/merchantApproval/merchantApprovalDone.jsp"
}
},{
"text":"商户不通过任务",
"attributes":{
"url":"pages/consume/approval/merchantApproval/merchantApprovalRefuse.jsp"
}
}]
}]
}]

就这样,我们使用easyui完成了简单的左右布局。

以上所述是小编给大家分享的jQuery Easyui实现上左右布局的相关内容,希望对大家有所帮助。

Javascript 相关文章推荐
JS target与currentTarget区别说明
Aug 28 Javascript
JQuery验证工具类搜集整理
Jan 16 Javascript
javascript:void(0)是什么意思示例介绍
Nov 17 Javascript
Javascript中的Callback方法浅析
Mar 15 Javascript
jquery使用hide方法隐藏指定id的元素
Mar 30 Javascript
原生JS实现N级菜单的代码
May 21 Javascript
JQuery通过后台获取数据遍历到前台的方法
Aug 13 jQuery
Vuejs2 + Webpack框架里,模拟下载的实例讲解
Sep 05 Javascript
Vue实现微信支付功能遇到的坑
Jun 05 Javascript
vue实现element表格里表头信息提示功能(推荐)
Nov 20 Javascript
详解vue-flickity的fullScreen功能实现
Apr 07 Javascript
javascript实现移动端上传图片功能
Aug 18 Javascript
AngualrJS中的Directive制作一个菜单
Jan 26 #Javascript
js实现网页图片延时加载 提升网页打开速度
Jan 26 #Javascript
详解javascript new的运行机制
Jan 26 #Javascript
在Linux系统中搭建Node.js开发环境的简单步骤讲解
Jan 26 #Javascript
基于JavaScript实现瀑布流布局(二)
Jan 26 #Javascript
AngualrJS中每次$http请求时的一个遮罩层Directive
Jan 26 #Javascript
JavaScript html5 canvas画布中删除一个块区域的方法
Jan 26 #Javascript
You might like
PHP Smarty模版简单使用方法
2016/03/30 PHP
Yii框架实现记录日志到自定义文件的方法
2017/05/23 PHP
PHP安装memcache扩展的步骤讲解
2019/02/14 PHP
JavaScript 变量命名规则
2009/09/23 Javascript
Javascript alert消息换行的方法
2013/08/07 Javascript
jQuery的bind()方法使用详解
2015/07/15 Javascript
jQuery链式操作实例分析
2015/11/16 Javascript
javascript 继承学习心得总结
2016/03/17 Javascript
使用jquery获取url以及jquery获取url参数的实现方法
2016/05/25 Javascript
jquery-mobile表单的创建方法详解
2016/11/23 Javascript
谈谈JavaScript中浏览器兼容问题的写法小议
2016/12/17 Javascript
NodeJs模拟登陆正方教务
2017/04/28 NodeJs
微信小程序 获取session_key和openid的实例
2017/08/17 Javascript
ES6扩展运算符和rest运算符用法实例分析
2020/05/23 Javascript
Vue-router编程式导航的两种实现代码
2021/03/04 Vue.js
python简单读取大文件的方法
2016/07/01 Python
Python选课系统开发程序
2016/09/02 Python
python实现图像识别功能
2018/01/29 Python
使用python PIL库实现简单验证码的去噪方法步骤
2019/05/10 Python
Python中的引用和拷贝实例解析
2019/11/14 Python
python numpy数组中的复制知识解析
2020/02/03 Python
Python BeautifulReport可视化报告代码实例
2020/04/13 Python
分享30个新鲜的CSS3打造的精美绚丽效果(附演示下载)
2012/12/28 HTML / CSS
意大利综合购物网站:Giordano Shop
2016/10/21 全球购物
汉米尔顿手表官网:Hamilton
2020/09/13 全球购物
2014三八妇女节活动总结范文四篇
2014/03/09 职场文书
财务担保书范文
2014/04/02 职场文书
班主任对学生的评语
2014/04/26 职场文书
科技工作者先进事迹
2014/08/16 职场文书
2014年酒店年度工作总结
2014/12/10 职场文书
毕业实习计划书
2015/01/16 职场文书
保险公司反洗钱宣传活动总结
2015/05/08 职场文书
党员转正大会主持词
2015/07/02 职场文书
公共场所卫生管理制度
2015/08/05 职场文书
《追风筝的人》:人心中的成见是座大山,但请不忘初心
2019/11/15 职场文书
python 逐步回归算法
2021/04/06 Python