Vue中使用Vue-scroll做表格使得在x轴滑动

页面效果

首先

npm i vuescroll

在main.js中挂载到全局

页面代码

<template>
    <div class="app-container">
        <Header :title='title' @goback='goBack'>
            <template v-slot:icon>
                <van-icon @click='goHome' class='icon' name='wap-home-o' />
            </template>
        </Header>
        <div class="table_box">
            <vue-scroll :ops="ops" style="width:100%;height:100%">
            <div class="data-box">
                <van-row class="th-row" style="display:flex;">
                    <van-col style="width:90px;text-align: center;border-right: 1px solid #ddd;">序号</van-col>
                    <van-col style="width:90px;text-align: center;border-right: 1px solid #ddd;">门店名称</van-col>
                    <van-col style="width:90px;text-align: center;border-right: 1px solid #ddd;">是否认购</van-col>
                    <van-col style="width:90px;text-align: center;border-right: 1px solid #ddd;">认购目标(分)</van-col>
                    <van-col style="width:90px;text-align: center;border-right: 1px solid #ddd;">本月完成(分)</van-col>
                    <van-col style="width:90px;text-align: center;border-right: 1px solid #ddd;">是否达时序</van-col>
                    <van-col style="width:90px;text-align: center;border-right: 1px solid #ddd;">当前进度</van-col>
                    <van-col style="width:90px;text-align: center;border-right: 1px solid #ddd;">是否需预警</van-col>
                </van-row>

                <!-- 数据循环展示,checkbox可以进行选择-->
                <van-row class="td-row" :style="{ background: index % 2 == 0 ? '#fefefe' : '#f3f3f3' }"
                    v-for="(item, index) in accountList" :key="index">
                    <van-col class="common-ellipsis" @click="showContent(item.workerNo)">{{ item.workerNo }}</van-col>
                    <van-col class="common-ellipsis" @click="showContent(item.workerName)">{{ item.workerName }}</van-col>
                    <van-col class="common-ellipsis" @click="showContent(item.salary)">{{ item.salary }}</van-col>
                    <van-col class="common-ellipsis" @click="showContent(item.amount)">{{ item.amount }}</van-col>
                    <van-col class="common-ellipsis" @click="showContent(item.amountTime, 1)">{{ item.amountTime
                        |dateFormat}}</van-col>
                    <van-col class="common-ellipsis" @click="showContent(item.remark)">{{ item.remark }}</van-col>
                    <van-col class="common-ellipsis" @click="showContent(item.remark)">{{ item.remark }}</van-col>
                    <van-col class="common-ellipsis" @click="showContent(item.remark)">{{ item.remark }}</van-col>
                </van-row>

            </div>
        </vue-scroll>
        </div>

        <!-- 弹出省略的内容 -->
        <van-popup v-model="showPopup" class="hidden-wrap">
            <van-row class="hidden-content">{{ ellContent }}</van-row>
        </van-popup>
    </div>
</template>
<script>
import Header from '../components/header'
export default {
    name: "vantTable",
    components: { Header },
    filters: {
        dateFormat: function (val) {
            //省略......
            return val;
        }
    },
    data() {
        return {
            title: "积分认购一览表",
            dataform: {
                queryStr: '',
            },
            isCheckAll: false,
            showPopup: false, // 显示省略的内容
            ellContent: "", // 省略的内容
            costName: "",
            checkedVal: [],
            accountList: [
                { workerNo: "1", workerName: "张良", salary: "1000", amount: "50000", amountTime: "20021201", remark: "弄啥咧" },
                { workerNo: "2", workerName: "天明", salary: "1111", amount: "40000", amountTime: "20021203", remark: "弄啥咧" },
                { workerNo: "3", workerName: "少司命", salary: "1222", amount: "60000", amountTime: "20021001", remark: "弄啥咧" },
                { workerNo: "4", workerName: "高渐", salary: "1333", amount: "20000", amountTime: "20021021", remark: "弄啥咧" },
                { workerNo: "5", workerName: "雪女", salary: "1444", amount: "10000", amountTime: "20020801", remark: "弄啥咧" },
            ],
            ops: {
                vuescroll: {},
                scrollPanel: {},
                rail: {
                    keepShow: true
                },
                bar: {
                    hoverStyle: true,
                    onlyShowBarOnScroll: false, //是否只有滚动的时候才显示滚动条
                    background: "#F5F5F5",//滚动条颜色
                    opacity: 0.5,//滚动条透明度
                    "overflow-y": "hidden" //使用横向滚动 竖向就是"overflow-x": "hidden"
                }
            }
        };
    },
    created() { },
    methods: {
        goBack() {
            this.$router.go(-1)
        },
        goHome() {
            this.$router.push('/index')
        },
        // 显示省略的内容
        showContent(content, type) {
            if (content == "") {
                return;
            } else {
                if (type == 1) {
                    var format = this.$options.filters['dateFormat'];
                    //日期通过过滤器格式化一下
                    this.ellContent = format(content)
                } else {
                    this.ellContent = content;
                }
                this.showPopup = true;
            }
        },
        checkAll() {
            if (!this.isCheckAll) {
                this.$refs.checkboxGroup.toggleAll(true);
                this.isCheckAll = true;
            } else {
                this.$refs.checkboxGroup.toggleAll();
                this.isCheckAll = false;
            }
        },
        onSearch() {

        },
        cLearSearch() {

        },
        checkChange() {

        },

    },
};
</script>

<style lang="less" scoped>
.app-container{
    background-color: #fff;
    height: 100vh;
    .table_box{
    padding: 10px;
    margin-top: 20px;
    .data-box {
    font-size: 13px;
    margin: 12px 0px;
    border: 1px solid #d0f2f0;

    .th-row {
        height: 30px;
        line-height: 30px;
        padding: 0px 12px;
        background: #d0f2f0;
    }

    .td-row {
        height: 30px;
        line-height: 30px;
        padding: 0px 12px;
    }

}

}
}


// 超出 1 行显示省略号
.common-ellipsis {
    width: 90px;
    height: 100%;
    overflow: hidden;
    white-space: nowrap;
    text-overflow: ellipsis;
    border-right: 1px solid #ddd;
    text-align: center;
}


// 滚动条位置 --展示横向
/deep/.__bar-is-vertical {
    display: none !important;
}

// 隐藏横向滚动条
/deep/.__bar-is-horizontal {
    bottom: -1px !important;
}
</style>

其中有个组件的代码header.vue

<template>
  <div class="head_box">
    <header>
      <div class="back">
        <img @click="goBack" src="../assets/back_on.png" alt="" />
      </div>
      <div class="home_title_container">
        <h3 style="font-weight: normal;font-size: 20px;">{{title}}</h3>
      </div>
      <div class="home_func">
        <slot name="icon"></slot>
      </div>
    </header>
  </div>
</template>
<script>
export default {
  name: 'org',
  props:{
    title:{

    }
  },
  data() {
    return {
    }
  },
  methods: {
    goBack() {
      this.$emit('goback')
    },
  },
}
</script>
<style lang="less" scoped>
.head_box{
  height: 2rem;
}
header {
  z-index: 999;
  color: red;
  text-align: center;
  height: 3rem;
  background: url('../assets/bg1.png');
  width: 100%;
  background-size: 100% 100%; // 可以使用cover
  background-repeat: no-repeat;
  background-origin: border-box; //从border开始填充
  background-clip: border-box;
  display: flex;
  justify-content: center;
  position: fixed;
  top: 0;
  .back {
    padding-left: 15px;
    img {
      align-self: center;
      display: flex;
      flex-direction: column;
      justify-content: center;
      height: 1.5rem;
    }
    width: 20%;
    height: 100%;
    text-align: left;
    flex: 1;
    display: flex;
    flex-direction: column;
    justify-content: center;
  }
  .home_func {
    display: flex;
    justify-content: center;
    flex: 1;
    width: 30%;
    height: 100%;
    font-size: 1.6rem;
    line-height: 1.5rem;
    color: #fff;
    .icon {
      display: flex;
      justify-content: center;
      flex-direction: column;
      text-align: center;
    }
    img{
      display: inline-block;
      width: 30px;
      height: 30px;
      align-self: center;
    }
  }
  .home_title_container {
    width: 70%;
    // height: 1.207729rem;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-direction: column;
    font-size: 0.434783rem;
    line-height: 0.724638rem;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    color: #fff;
    h4 {
      font-size: 0.434783rem;
      line-height: 0.483092rem;
      height: 0.483092rem;
      overflow: hidden;
      text-overflow: ellipsis;
      white-space: nowrap;
    }
  }
}
</style>

注意

记得替换图片    !!!!

vant版本是2.x   !!!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/654802.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

深度解析Java 11核心新特性

码到三十五 &#xff1a; 个人主页 < 免责声明 > 避免对文章进行过度解读&#xff0c;因为每个人的知识结构和认知背景都不同&#xff0c;没有一种通用的解决方案。对于文章观点&#xff0c;不必急于评判。融入其中&#xff0c;审视自我&#xff0c;尝试从旁观者角度认清…

爬虫实战教程:深入解析配乐网站爬取1000首MP3

新书上架~&#x1f447;全国包邮奥~ python实用小工具开发教程http://pythontoolsteach.com/3 欢迎关注我&#x1f446;&#xff0c;收藏下次不迷路┗|&#xff40;O′|┛ 嗷~~ 目录 一、引言 二、实战前准备 1. 选择目标网站 2. 分析网页结构 三、爬虫工作流程详解 1. 发…

内网穿透入门使用(frp和natapp)

内网穿透入门使用 简单介绍穿透工具推荐FrpFrp下载安装服务端配置启动服务端配置客户端启动客户端效果查看 NATAppNATApp下载安装NATApp配置启动NATApp 使用途径 我的博客&#xff1a;Lichg&#xff0c;欢迎大家访问留言。 简单介绍 什么是内网穿透&#xff1a; 首先我们对内网…

lvm概述和配额

lvm概述和配额 文章目录 lvm概述和配额LVM概述1、逻辑卷的作用&#xff1a;2、lvm主要命令和实操磁盘配额创建data目录&#xff0c;进入data目录限制创建文件数 LVM概述 逻辑卷管理liunx系统下对硬盘分区的一种管理机制 lvm机制特别适合管理大储存设备&#xff0c;可以动态的…

Echarts x轴坐标二级分组

在使用echarts 封装组件的时候&#xff0c;偶尔会遇到需要x轴坐标进行二层分组的需求。那么如何对echarts 进行二层分组呢&#xff0c;有以下几个步骤&#xff1a; 仅介绍二层分组的逻辑。有兴趣的可以进行三层延伸。 1&#xff0c;修改echarts Options 中xAxis 的配置。 此…

win11中文文件名称乱码解决方案

解压后出现以下的乱码 解决方案 步骤1.winR 输入intl.cpl 或 windows 自带的搜索搜“intl.cpl”&#xff0c;打开这个面板控制项 步骤2.在新打开的区域面板中&#xff0c;选择“管理”标签页&#xff0c;点击下方的“更改系统区域设置”按钮 步骤3.取消"Beta版…"选…

如何将RK R75键盘的右Alt键改为Ctrl键

打开注册表地址栏中输出 计算机\HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Control\Keyboard Layout右键新建二进制值&#xff0c;名称设为ScanCode Map按下图输入数值

【NumPy】全面解析NumPy的bitwise_and函数:高效按位与操作指南

&#x1f9d1; 博主简介&#xff1a;阿里巴巴嵌入式技术专家&#xff0c;深耕嵌入式人工智能领域&#xff0c;具备多年的嵌入式硬件产品研发管理经验。 &#x1f4d2; 博客介绍&#xff1a;分享嵌入式开发领域的相关知识、经验、思考和感悟&#xff0c;欢迎关注。提供嵌入式方向…

鸿蒙4.2小版本推出,鸿蒙5.0已经不远了

上个月&#xff0c;市场上迎来了华为鸿蒙系统4字开头的小升级&#xff0c;版本来到了4.2版本。 我们先来看看4.2版本都给用户带来哪些特色&#xff1a; 界面切换更流畅&#xff1a;无论是响应速度还是操作手感&#xff0c;用户都将感受到更加迅速和顺滑的体验 搜星速度的显著…

磁盘管理以及文件系统08

1、为什么要对磁盘进行分区&#xff1f; 业务层面&#xff1a;为满足一定的需求所是做的特定操作。 2、硬盘是什么&#xff0c;以及硬盘的作用 硬盘&#xff1a;计算机的存储设备&#xff0c;一个或者多个带磁性的盘组成的&#xff0c;可以在盘片上进行数据的读写。硬盘的最…

深入解析Python中的两种导入方法:from...import与import

新书上架~&#x1f447;全国包邮奥~ python实用小工具开发教程http://pythontoolsteach.com/3 欢迎关注我&#x1f446;&#xff0c;收藏下次不迷路┗|&#xff40;O′|┛ 嗷~~ 目录 一、引言 二、from...import与import的基本区别 1. 导入方式的不同 2. 命名空间的差异 三…

开源与闭源:AI大模型发展路径的博弈

一、引言 在人工智能&#xff08;AI&#xff09;领域&#xff0c;大模型以其卓越的性能和广泛的应用前景&#xff0c;成为了近年来技术发展的热点。然而&#xff0c;在大模型的发展路径上&#xff0c;开源与闭源两种模式一直存在着激烈的博弈。本文将深入探讨这两种模式在大模…

ZooKeeper安装

安装Zookeeper 1、下载Zookeeper安装包 打开链接选择一个版本进行下载 https://zookeeper.apache.org/releases.html2、上传Zookeeper安装包到集群 输入命令 scp apache-zookeeper-3.8.4-bin.tar.gz hadoop192.168.88.100:/tmp也可以使用xftp等上传&#xff0c;物理机用u盘…

DINO结构中的exponential moving average (ema)和stop-gradient (sg)

DINO思路介绍 在 DINO 中&#xff0c;教师和学生网络分别预测一个一维的嵌入。为了训练学生模型&#xff0c;我们需要选取一个损失函数&#xff0c;不断地让学生的输出向教师的输出靠近。softmax 结合交叉熵损失函数是一种常用的做法&#xff0c;来让学生模型的输出与教师模型的…

C++学习笔记(19)——模板

目录 模板参数与非类型模板参数 模板参数 类型模板参数——传递类型 非类型模板参数——传递数量 C11希望array替代静态数组&#xff0c;但实际上vector包揽了一切 模板总结 优点&#xff1a; 缺点&#xff1a; 模板特化&#xff1a;针对某些类型进行特殊化处理 特化…

代码随想录算法训练营第五十三天||1143.最长公共子序列、1035.不相交的线、53. 最大子序和

文章目录 一、1143.最长公共子序列 思路 二、1035.不相交的线 思路 三.53. 最大子序和 思路 一、1143.最长公共子序列 给定两个字符串 text1 和 text2&#xff0c;返回这两个字符串的最长公共子序列的长度。 一个字符串的 子序列 是指这样一个新的字符串&#xff1a;它是由原…

mysql中text,longtext,mediumtext区别

文章目录 一.概览二、字节限制不同三、I/O 不同四、行迁移不同 一.概览 在 MySQL 中&#xff0c;text、mediumtext 和 longtext 都是用来存储大量文本数据的数据类型。 TEXT&#xff1a;TEXT 数据类型可以用来存储最大长度为 65,535(2^16-1)个字符的文本数据。如果存储的数据…

stream-实践应用-统计分析

背景 业务部门提供了一个数据&#xff0c;数据甚至不是excel类型的&#xff0c;是data.txt&#xff0c;每一行都是一个数据&#xff0c;需要对此数据进行统计分析 统计各个月份的销量 因为直接获取resources下的data.txt&#xff0c;所以要借助输入流进行获取数据&#xff0c;再…

初识C语言——第二十六天

函数的递归1 什么是递归呢&#xff1f; 递归的两个必要条件 void print(unsigned int n) {if (n > 9){print(n / 10);}printf("%d ", n % 10); }int main() {unsigned int num 0;scanf("%u", &num);//123//递归-函数自己调用自己print(num);//pr…

Scrapy框架简单介绍及Scrapy项目编写详细步骤(Scrapy框架爬取豆瓣网站示例)

引言 Scrapy是一个用Python编写的开源、功能强大的网络爬虫框架&#xff0c;专为网页抓取和数据提取设计。它允许开发者高效地从网站上抓取所需的数据&#xff0c;并通过一系列可扩展和可配置的组件来处理这些数据。Scrapy框架的核心组成部分包括&#xff1a; Scrapy Engine&…