zoukankan      html  css  js  c++  java
  • 扩充 jQuery EasyUI Datagrid 数据行鼠标悬停/离开事件(onMouseOver/onMouseOut)

    客户需求:

    jQuery EasyUI Datagrid 用户列表鼠标悬停/离开数据行时显示人员头像(onMouseOver/onMouseOut)

    如图所示,Datagrid 鼠标悬停/离开数据行时切换了不同的样式显示:

    此时用谷歌开发者工具审查鼠标悬停行元素时发现,table tr 节点 class 属性中增加了 datagrid-row-over 样式:

    于是打开 jquery.easyui.min.js 脚本,查找 datagrid-row-over 关键字,6983 行中发现关键字:

    根据脚本 6974 行看出,此段脚本是为 Datagrid 绑定 mouseover 事件,紧接着便是 mouseout 事件的绑定。

    之后参照文章http://www.loststop.com/archive/soft-and-internet/3819.html修改,发现作者用的版本为 jQuery EasyUI 1.2.4 ,奈何 jQuery EasyUI 现在已更新版本至 1.3.4(注:本文使用 jQuery EasyUI 1.3.2 版),脚本内容较之前版本变化太大,遂照葫芦画瓢摸索着扩展了 Datagrid 的 mouseover  及 mouseout 事件,具体步骤如下:

    1、扩展添加 onMouseOverRow 事件

    [javascript] view plain copy print?
    1. var row=opts.finder.getRow(_4a5,_4af);  
    2. opts.onMouseOverRow.call(_4a5,e,_4af,row);  


    扩展后如图所示:

    2、扩展添加 onMouseOutRow 事件

    [javascript] view plain copy print?
    1. var row=opts.finder.getRow(_4a5,_4b1);  
    2. opts.onMouseOutRow.call(_4a5,e,_4b1,row);  


    扩展后如图所示:

    至此,只需四句代码即可实现 Datagrid mouseover 及 mouseout 事件的扩展,扩展后具体应用如下:

    [javascript] view plain copy print?
    1. <script type="text/javascript">  
    2.     $(function(){  
    3.         $('#baidu').datagrid({  
    4.             url: 'www.baidu.com',  
    5.             fit:true,  
    6.             fitColumns: true,  
    7.             pagination:true,  
    8.             pageSize:10,  
    9.             pageList:[10,20,50,80],  
    10.             singleSelect:true,  
    11.             onMouseOverRow:function(e, rowIndex, rowData){  
    12.                 alert("Over~");  
    13.             },  
    14.             onMouseOutRow:function(e,rowIndex, rowData){  
    15.                 alert("Out~");  
    16.             }  
    17.         });  
    18.     });  
    19. </script>  

    扩展 jQuery EasyUI Datagrid 数据行鼠标悬停离开事件demo下载:http://download.csdn.net/detail/for_china2012/6419133

    效果图如下:


    【第二种实现方式】


    这种方式较第一种来说简单实用,具体实现代码如下:

    1. onLoadSuccess:function(){  
    2.     $(".datagrid-row").mouseover(function(){  
    3.         var url = $(this).children("td").eq(0).text();  
    4.         if (url == "") {  
    5.             $("#show_img").attr("src", "${ctx}/images/person.jpg");  
    6.         } else {  
    7.             $("#show_img").attr("src", "${ctx}/" + url);  
    8.         }  
    9.         $("#preview").css("top", ($(this).offset().top - xOffset) + "px").css("left", ($(this).offset().left + yOffset) + "px").fadeIn("slow");  
    10.     });  
    11.     $(".datagrid-row").mouseout(function(){  
    12.         $("#preview").hide();  
    13.     });  
    14. }  

    在 DataGrid 初始化时通过 onLoadSuccess 时间绑定数据表格行鼠标悬停离开事件,审查元素得知,DataGrid 生成的数据表格行都含有class=“datagrid-row”样式,之后通过 jQuery 获得当前行下指定列内容即可:

    [javascript] view plain copy print?
    1. var url = $(this).children("td").eq(0).text();  

    获得内容之后怎么处理就交给你了。。。

  • 相关阅读:
    微软面试100 题题解
    二元查找树转变成排序的双向链表(树)
    筆試
    PE注入
    内核网络通信
    哈哈哈
    OpenCV 学习
    第一次研究VM程序中的爆破点笔记
    SE2.3.4各试用限制调试笔记
    破解相关书籍
  • 原文地址:https://www.cnblogs.com/pureEve/p/6649650.html
Copyright © 2011-2022 走看看