日期:2014-05-16  浏览次数:20927 次

ASP.NET冻结列

最终要的效果

 

 

前面几个列固定 后面滚动条显示隐藏值

 

经过练习48个小时的摧残,尼玛终于搞定了,苦逼啊.............

最近要在ASP.NET项目中使用冻结列那些鬼东西,然后网上各种查找,然后找到个不错的能够手动设置冻结哪几列的

地址http://download.csdn.net/detail/qq873113580/6461653

可是这个引用的东西太多了 ,手动写了N多JS N多CSS,好吧 ,为了工作拼,耐心修改成自己想要的样式

 

然后....活动列和冻结列 内容高度一样的时候 还蛮好看的,但是内容动态获取出来之后有些高度不一样 冻结列和未冻结列就无法正常显示了,坑

好吧,我承认 不怎么想去看里面代码怎么实现了.............

 

 

继续找.........听说第三方控件DevExpress也不错,然后找到了地址

http://download.csdn.net/detail/xiongjianx/4921864   第一部分

http://download.csdn.net/detail/xiongjianx/4922052  第二部分

 

下载好了,收费的.........直接略过....,对于自己用还是不错的

 

 

继续找,

http://feipigwang.iteye.com/blog/1204137

貌似代码比较简单了,但是,全部复制没效果啊,不知道这个大神怎么显示出来的,加了QQ木反应,

然后想是不是expression(this.parentElement.parentElement.parentElement.parentElement.parentElement.scrollLeft);这里的问题

,修改成JS试试,就是把left的值动态获取,哇塞出来了,主要思路是滚动条每滚动一次获取LEFT  TOP的值 用Position控制,可是效果很渣渣

每次拖动滚动条,被冻结的列都会闪烁,主要是动态改变left top的值造成的,就在绝望滴时候,脑中闪过一片灵光,顿时王八之气一抖,汗一个,好老套的剧情。。。。

-_-!!!!!!!!!!!!!!!

突然想到了table套table

 

列头在第一个 table thead  里面 滚动条在tfoot里面 夸要 活动的列,然当滚动条滚动的时候同时上面所有隐藏的列滚动条也滚动,就OK了,

 

PS:由于是table套table 组合而成的,所以2个table的css要一样 这个最重要的

 

丢源码上来,思路例子效果,不过这个是只设置了一列,多列也可参考这种思维,毕竟 这样布局比较清楚,然后修改样式也容易修改,对于我等新手来说 还算不错了,(*^__^*) 嘻嘻……

 

<%@ Page Language="C#" AutoEventWireup="true" CodeBehind="Index1.aspx.cs" Inherits="冻结列.Index1" %>

<!DOCTYPE html>

<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
    <title></title>
    <script type="text/javascript" src="jquery-1.4.1.js"></script>
    <script type="text/javascript">
        $(function () {
            //最下面滚动的时候,把上面的所有隐藏的一起滚动
            $(".activeCol").scroll(function () {
                if ($(this).attr("id") == "scrollBar") {
                    var left = $(this).scrollLeft();
                    $(".activeCol").each(function (i) {
                        if ($(this).attr("id") != "scrollBar") {
                            $(this).scrollLeft(left);
                        }
                    });
                }
            });
        });
    </script>

    <style type="text/css">
        table, td, tr {
            margin: 0px;
            padding: 0px;
        }

        table {
            border-collapse: collapse;
        }

        td {
            border: solid 1px black;
        }
    </style>
</head>
<body>
    <form id="form1" runat="server">
        <div>
            <table>
                <!--手动设置头部Start-->
                <thead>
                    <tr>
                        <td>1</td>
                        <td>1</td>
                        <td>1</td>
                        <td>1</td>
                    </tr>
                </thead>
                <!--手动设置头End-->
                <tbody>
                    <tr>
                        <td colspan="4">
                            <!--这里设置中间显示的内容区域-->
                            <div style="width: 550px; height: 400px; overflow-x: hidden; overflow-y: auto;">