美文网首页我爱编程
二、easyui笔记

二、easyui笔记

作者: 毛小意 | 来源:发表于2018-06-07 10:59 被阅读0次

学习笔记一:jquery学习

Ceng coding的用法

Css速写:一般css样式都是开头简写+tab键补全,样式就是简写+:样式的格式,例如:o:h  是overflow:hidden;

html速写:例:div#a+div#b+div.c-$*5+li*10生成的样式如下:

选择器:

#id 用于搜索的,通过元素的id属性中给定的值

$("#content")匹配id   $(".content")匹配class   $("ul")匹配标签 $("*")匹配所有的标签

$("ul,input,span")找到匹配任意一个类的元素

层级:

$("ul>li") ul下的所有li标签

$("label+input") 匹配所有跟在label后面的 input 元素

$("form ~input")找到所有与表单同辈的input元素。

基本筛选器:

:first匹配第一个

:not()匹配未选中的数据

$("input:not(:required)").val("12");

<input type="text" value="0" name ="apple" />

<input type="text" name="flower" id="" value="1" required />

:even匹配元素里的偶数

:odd匹配元素里的奇数

:eq()   匹配一个给定索引值的元素

:gt()   匹配所有大于给定索引值的元素

:lt(index) 匹配所有小于给定索引值的元素

<input type="text" value="0" name="apple" />

<input type="text" name="flower" id ="" value="1" required />

常用:

Each()遍历每个元素

Size()=Length元素的长度或者字符的长度

Get(index)获取指定索引的元素

Html代码/文本/值

获取值:text()获取元素的内容 val() 获取元素的值

两者区别:val()在input标签里面。获取value的值。在成对出现的文本框里取值为text()的值。

事件:

Ready()页面加载

On()用于绑定事件

Hover()鼠标悬停在元素上触发的函数

$("td").hover( function () {   $(this).addClass("css01");},

function () {$(this).removeClass("css01");});

Toggle()  用于确定显示/隐藏的开关

blur()鼠标移开触发的事件

change()改变事件的状态触发的事件

click()点击事件。

dblclick()双击触发的事件

error()用于报错提示,字体会变成红色

focus()获得焦点

keydown()   当键盘或按钮被按下时,发生keydown事件。

keypress()  当键盘或按钮被按下时,发生keypress事件。

keyup()     当按钮被松开时。它发生在当前获得焦点的元素上。

resize()    当调整浏览器窗口的大小时

scroll()

select()   当textarea或文本类型的 input 元素中的文本被选择时,会发生 select 事件。

submit()提交表单的时候

unload()加载

取标签得name值,

$("#a1").attr("name","123456")

取元素都是一个数组--->取值的话要遍历-->arr[i]只是遍历元素 -->遍历里面的元素用text()

任务一:设置所有父标签下的第一个子标签的样式:

//取ul下的所有第一个li标签,颜色变红

$("ul>li:first-child").each(function(){ $(this).addClass("css01"); });

任务二:设置动态生成的标签的绑定事件

//动态生成的html元素,怎么绑定事件

$("#div1").html("<h1>6666</h1>");

$("#div1>h1").on("click",function(){  alert(9);  });

学习笔记二:easyui学习

简单的引用在easyui demo里面配置好easyui的css样式引用和easyui封装好的基础js包。

 <link rel="stylesheet" type="text/css" href="../static/easyui/themes/bootstrap/easyui.css" />

<link rel="stylesheet" type="text/css" href="../static/easyui/themes/icon.css" />

<script type="text/javascript" src="../static/easyui/jquery.min.js"></script>

<script type="text/javascript" src="../static/easyui/jquery.easyui.min.js"></script>

<script type="text/javascript" src="../static/easyui/locale/easyui-lang-zh_CN.js"></script>

引用好之后,直接在easyui demo里面复制代码,如需js动态则使用easyui 插件。

例:$("#nav").accordion({animate:true}); //定义当展开或折叠面板(panel)时是否显示动画效果。

iconCls:'icon-save' 显示图标

常用的布局:

面板:class="easyui-panel"

布局:class="easyui-layout"  title="East" 是否可以隐藏

顶部:north   底部:south  左侧: west  右侧: east  中心: center

手风琴:class="easyui-accordion" 设置手风琴是否打开 style="overflow:auto;"

选项卡:class="easyui-tabs"  设置选项卡是否关闭 data-options="closable:true"

菜单:class="easyui-menu"

表单:class="easyui-textbox"

数据表格:class="easyui-datagrid"

分页:class="easyui-pagination"

<div class="easyui-panel">

<div class="easyui-pagination" dada-option="total:114"></div></div>

日历:class="easyui-calendar"

日期插件:Js插件:$('#dd').datebox({required: true });

//拖拽:class="easyui-draggable"

handle  selector启动可拖动(draggable)的处理(handle)。

文件树形结构:class="easyui-tree"一般文档路径正常放在json里面

<ul class="easyui-tree" data-option="url:'tree_data1.json",method:"get",animate:true,lines:true"></ul>

按钮:

<a href="javascript:void(0)" class="easyui_linkbutton" data-options="plain:true,iconCls:"icon-add'" onclick="addPanel()"></a>

选项卡工具卡:(不仅tabs可以,panel面板也可以)

function addPanel(){    index++;    $('#tt').tabs('add',{        title: 'Tab'+index,       

 content:"<div style="padding;10px">Content"+index+"</div>" ,        closable:true   });}

数据绑定:

消息框:

基础消息框

$.messager.show({    title:'My Title',    msg:'Message will be closed after 4 seconds.',    showType:'show'/'slide'/'fade'});

class                         title                        例子

基础面板           easyui-panel           Basic Panel

流式面板          easyui-panel            Fluid Panel

面板工具          easyui-panel            Panel Tools

用户面板工具   easyui-panel          data-options="iconCls:'icon-save',closable:true,tools:'#tt'"

载入面板工具  easyui-panel           

data-options="tools:[{ iconCls:'icon-reload',handler:function(){$('#p').panel('refresh','_content.html');}}]"

面板尾部        easyui-panel           Panel Footer

面板嵌套        easyui-panel          Nested Panel

注意:

如果用到textbox的时候获取值        $('# id).textbox('getValue')

用到combox下拉框                         $("# id ").combobox('getValue')

easyui日期控件取值                    Databox $('#mdate').datebox('getValue')

学习笔记三:easyui树形结构

zTree插件:

比easyui的好处是:zTree的json结构是{id:xxx,pId:xxx,name:xxx}的结构,其中子级的pId就是对应的父级的id。一般数据库中的数据(例如:部门表)就是对应:自己的部门编号,部门名称,上级部门编号。

而esayui的自带的tree结构是{id:xxx,text:xxx,children:[{id:xxx,text:xxx]}这样的结构需要sql语句进行稍微复杂处理所以就不建议使用。

实现过程和特别指出来的点:需要在model下建一个数据库里不对应的类用于放id,pId,name的字段。查出的结果直接放到json对象里返回到数据。

图一  传输格式

页面放值

图二  树结构

树结构的进一步应用

树结构点击到哪里右边数据就显示出对应的条件的结果。

在树结构添加点击事件:根据API了解ztree自带onclick事件。

在setting里增加callback里的onclick事件。

图三 添加点击事件

绑定事件:点击查询的方法。

图四 事件传参

学习easyui对应的数据封装:

初始化方法封装:--->   $(function(){    new civilianPayroll().init();});

方法里写初始化的表格和按钮:--->

this.init = function () {    civilianPayrollList.initGrid();    civilianPayrollList.initQuery();}

具体初始化表格:数据绑定easyui的datagrid数据网格属性。

或者按钮:--->里面具体的实现方法:点击事件onclick

图五 事件

定义url把后台的请求路径放进去。

学习笔记四:easyui数据绑定

提高性能:页面分页和加载:

Easyui的数据绑定,分页功能:

图六 分页设置

默认50条数据一页;

加载,不分页:

图七 滚动方法

Easyui自带的滚动效果view:scrollview,每次只加载固定的条数,之前加载的数据就会被清空掉。所以重新写了方法:bufferview。加载不会清除之前加载的数据。

进行全选也不会出现,选择了的数值被清空掉的问题。

如果进行前几行冻结效果:

当使用easyui的datagrid时,需注意frozenColumns参数,只能冻结不需要改变,不是流式布局的列,当行合并时可以使用它,当列下面有子列时,不能使用。

学习笔记五:事业部与部门联动

下拉框和联动:部门表用树形结构显示,效果如下图:

图八 下拉框设置

js页面的效果:先在事业部绑定下拉框,数据从数据库拉出来。

通过onSelect事件传递事业部的id查询出事业部下的大区和事业部。

$('#sendSuperiorSite').combobox({    url: franchiseeList.URL.site,    valueField:'id',    textField:'siteName',    onSelect: function(rec){       

 //============弹出框的树结构=================================//        

$("#siteName").combotree({            method:'post',            

url:franchiseeList.URL.dept+'?id='+rec.id,            

parentField:"superiorSite",            

textFiled:"siteName",            idFiled:"siteName",            editable:true,            lines:true        });    }});

Easyui自带的树结构是嵌套的,所以要重写成ztree的格式。

使用此方法在easyui.treex.js里面重写好了,可以直接调用:

方法: combotree绑定:

parentField为父级的ID或者标识,

idFiled 为本数据的ID或者标识

textFiled 为显示的字段。

部门二次联动,

$("#siteName").combotree({    method:'post',    url:franchiseeList.URL.dept+'?id='+rec.id,    parentField:"superiorSite",    textFiled:"siteName",    idFiled:"siteName",    editable:true,    lines:true});

Sql里的getSiteNode(#{superiorSite})函数是用于判断是否有子级部门,如果有子级则返回子级部门,如果没有就结束。最后返回String类型的数组。参数传的是部门名称。先通过函数查询出所有的子部门,

<select id="getSiteNames" parameterType="java.util.Map" resultType="string">

select getSiteNode(#{superiorSite})  </select>

再根据所有子部门查出这些子部门的集合信息。循环查询配置用

<foreach> <select id="getSiteByNames" parameterType="java.util.Map" resultMap="beaMap">

select * from t_site where site_name in

<foreach item="item" index="index" collection="siteNames" open="(" separator="," close=")">

    #{item}

</foreach>  </select>

学习笔记六:页脚合计

设置绑定的页脚为TRUE,

showFooter: true

页脚数据显示的json格式,所以在controller里面写下footer对应的字段:

,"footer":[ {……,"siteName":"统计结果"}]}

{"total":28,"rows":[ {"productid":"FI-SW-01","unitcost":10.00,"status":"P","listprice":36.50,"attr1":"Large","itemid":"EST-1"},]   

 ,"footer":[    {"unitcost":19.80,"listprice":60.40,"productid":"合计:"}]}

相关文章

  • 二、easyui笔记

    学习笔记一:jquery学习 Ceng coding的用法 Css速写:一般css样式都是开头简写+tab键补全,...

  • EasyUI入门案例

    EasyUI 简介 EasyUI下载 http://www.jeasyui.net/download EasyUI...

  • jQuery EasyUI 入门

    jQuery EasyUI 详解 EasyUI 简介 easyui 是一种基于 jQuery 的用户界面插件集合。...

  • 01Jquery EasyUI 快速入门

    1.1 Jquery EasyUI 简介 easyui是一种基于jQuery的用户界面插件集合。easyui为创建...

  • easyUI搭建与使用

    1 easyUI 简介 easyui就是一个前端框架,JQuery EasyUI是一组基于jQuery的UI插件...

  • jQueryEasyUI框架

    EasyUI 简介 easyui是一种基于jQuery的用户界面插件集合。easyui为创建现代化,互动,Java...

  • 高级第七天:EasyUI学习

    EasyUI学习 主要内容 1.前端开发框架的介绍 2.EasyUI的介绍和常用组件 3.EasyUI的组件使用 ...

  • 封装过的好的easyui 框架

    大神作品:修改版的easyui 作品 http://www.uimaker.com/easyui/

  • Easyui学习整理笔记

    @[toc]对工作中遇到的easyui做一下笔记,不定时更新 (1) 表格双击事件 datagrid和treegr...

  • EasyUI分页

    前端EasyUI自带 :

网友评论

    本文标题:二、easyui笔记

    本文链接:https://www.haomeiwen.com/subject/ibapsftx.html