zoukankan      html  css  js  c++  java
  • 滚动到Table的某个位置

    1. 需求:一张表格中包含多条“环境数据”和“日志数据”,要求点击“日志”按钮时滚动到“日志数据”,即视图中的第一行数据是“日志数据”。
    2. 效果图:点击“环境”按钮显示,点击“日志”按钮显示
    3. 实现(基于Vue、jQuery)
      1. html代码
    <button @click="handleModal(false)">环境</button>
    <button @click="handleModal(true)">日志</button>
    
    <Modal class="special-modal" 
          width="800"
          v-model="showModal"
          footer-hide>
          <div class="f-s-18 m-b-10">文件信息</div>
          <div class="table-title">
            <span class="self-title" style="14%">类别</span>
            <span class="self-title" style="66%">文件名</span>
            <span class="self-title" style="14%">状态</span>
          </div>
          <div class="scroll-container table-container">
            <table class="mytable" border>
              <tr v-for="(item, index) in fileData" :key="index" :id="index">
                <td width="14%" align="center">{{item.type}}</td>
                <td width="66%" align="center">{{item.fileName}}</td>
                <td width="20%" align="center">{{item.status}}</td>
              </tr>
            </table>
          </div>
    </Modal>

                       2.js代码

    handleModal(flag) {
            let scrollTime = 300
            let offsetTop = 2*(36+1) // 2是环境数据的个数,36是表格行高,1是边框高度
            if(flag) {
              jQuery(".scroll-container").animate(
                {
                  scrollTop: offsetTop,
                },
                scrollTime
              );
            } else {
              jQuery(".scroll-container").animate(
                {
                  scrollTop: -offsetTop,
                },
                scrollTime
              );
            }
            this.showModal = !this.showModal
          }

                    3.css代码

    /deep/.special-modal {
        .table-title {
           100%;
          height: 36px;
          line-height: 36px;
          background-color: #404851;
          font-size: 14px;
          color: #fff;
        }
        .self-title {
          display: inline-block;
          text-align: center;
        }
        .table-container {
          height: 200px; 
          overflow-y:auto;
        }
        // 表格滚动条
        .table-container::-webkit-scrollbar {
           14px;
          background: #1f252a;
        }
        .table-container::-webkit-scrollbar-thumb {
          height: 90px;
          border-radius: 7px;
          background:#404851;
        } 
        .table-container::-webkit-scrollbar-corner {
          background: #404851;
        }
        .mytable {
           100%;
          font-size: 14px;
          line-height: 36px;
          color: #ddd;
          background-color: #323b44;
          td {
            border: none;
            border-bottom: 1px solid #404851;
          }
        }
      }

                    4.数据

    fileData: [
              {
                type: '环境',
                fileName: 'xxxxxxxxxxxxxxxxxxxxxxxxx.bck',
                status: 1
              },
              {
                type: '环境',
                fileName: 'xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx.bck',
                status: 2
              },
              {
                type: '日志',
                fileName: 'xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx.bck',
                status: 3
              },
              {
                type: '日志',
                fileName: 'xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx.bck',
                status: 4
              },
              {
                type: '日志',
                fileName: 'xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx.bck',
                status: 5
              },
              {
                type: '日志',
                fileName: 'xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx.bck',
                status: 6
              },
              {
                type: '日志',
                fileName: 'xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx.bck',
                status: 7
              },
              {
                type: '日志',
                fileName: 'xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx.bck',
                status: 8
              },
              {
                type: '日志',
                fileName: 'xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx.bck',
                status: 9
              },
              {
                type: '日志',
                fileName: 'xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx.bck',
                status: 10
              },
              {
                type: '日志',
                fileName: 'xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx.bck',
                status: 11
              }
            ]
  • 相关阅读:
    设计模式:Prototype 原型模式
    [C++STDlib基础]关于单字符的操作——C++标准库头文件<cctype>
    Android开发之简单的电子相册实现
    autotools入门笔记(二)——创建和使用静态库、动态库
    Dreamer 框架 比Struts2 更加灵活
    Redis集群明细文档
    【Servlet3.0新特性】第03节_文件上传
    POJ 3264 Balanced Lineup
    利用jquery对ajax操作,详解原理(附代码)
    C语言实现修改文本文件中的特定行
  • 原文地址:https://www.cnblogs.com/liyan22/p/11528203.html
Copyright © 2011-2022 走看看