uniapp 表格组件,冻结首行首列
admin
2024-02-02 17:32:06
0

uniapp 表格组件,冻结首行首列

  • 模板
  • js
  • css 部分样式需要放到 `App.vue` 里面才能生效
  • 属性与方法
    • 属性
      • 列定义
      • 按钮
    • 方法
      • 行样式
      • 选择事件
      • 翻页事件
  • 使用组件

uni-table 的封装
优点:自带样式,自带多选等功能
缺点:
1. 不能对 checkboxvalue 进行赋值,选出来的选中行的 index
2. 不能对 checkbox 在加载完表格后默认选中
3. checkbox 不能设置默认禁用

模板


js

export default {name: "x-table",props: {/*** 数据列表* */list: {type: Array,default: []},/*** 是否开启多选* 默认否* */chk: {type: Boolean,default: false},/*** 列定义* */cols:{type:Object,default:null},/*** 按钮列宽度* */btnswidth:{type:Number,default:100},/*** 按钮列表* 请根据按钮数量设置 按钮列宽度* */btns:{type: Array,default: []},/*** 行样式* 可以设置背景色或文字颜色来标记不同的数据状态* */trstyle:{type:Function,default:function(){}},/*** 多选选择时触发* */chkchange:{type:Function,default:function(){}},/*** 设置表格高度 css* */height:{type:String,default:'800px'},/*** 每页长度* */pagesize:{type:Number,default:20},/*** 起始页* */pageindex:{type:Number,default:1},/*** 查询数据总量* */count:{type:Number,default:0},/*** 翻页事件* */topage:{type:Function,default:function(){}}},data() {return {};},methods:{/*** 翻页事件* current=翻页后的页码* */fpage(e){console.log(e)this.topage(e.current);},/*** 单元格数据格式化* */fmt(f,v,r){if(f){return f(v,r);}return v;}}}

css 部分样式需要放到 App.vue 里面才能生效

.x-table-btns button{height: 24px;line-height: 24px;font-size: 14px;display: inline-block;margin-right: 2px;}.x-table-box {width: 100%;background-color: #fff;height: 90%;overflow: auto;position: absolute;}.x-table{border-collapse: collapse;display: inline-block;overflow: auto;width: 100%;position: absolute;}.uni-table-scroll{height:calc(100% - 60px);}.uni-pagination-box{position: absolute;bottom: 0px;left: 0px;width: 100%;padding: 15px;box-sizing: border-box;}.x-table .thead {position: sticky;top: 0;z-index: 9;}.x-table th,.x-table td {box-sizing: border-box;background-color: #fff;}.x-table .checkbox {position: sticky;left: 0;z-index: 8;overflow: hidden;}.x-table .checkbox::before{content: "";position: absolute;right: -1px;top: -10px;height: 200%;width: 0.5px;box-shadow:0px 0px 5px #000;}.x-table tr {display: flex;}.x-table tr:hover,.x-table tr:hover td{background-color:#eee;}@media (min-width:768px) {.x-table-box {max-width: calc(100vw - 200px) !important;}.x-table .left5 {position: sticky;left:36px;border-right: 1px solid #eee;overflow: hidden;}.x-table .left5::before{content: "";position: absolute;right: -1px;top: -10px;height: 200%;width: 0.5px;box-shadow:0px 0px 5px #000;}}@media (max-width:768px){.x-table tbody{display: inline-block;width: 100%;}.x-table tr{flex-direction: column;background-color: #fff;border-bottom: #ccc;width: 100%;margin-bottom: 10px;}.x-table .thead{display: none;}.x-table th,.x-table td {border:none;width: 100%;}.x-table-btns{text-align: right;}.x-table-btns button{height:30px;line-height:30px;font-size: 14px;display: inline-block;margin-right:10px;}}

position: sticky; 与上级元素 position: absolute; 可做到冻结

属性与方法

属性

名称类型描述
listArray数据列表
colsObject列定义,详细信息见下面列定义
btnsArray按钮列表,请根据按钮数量设置—按钮列宽度,详细信息见下面按钮
btnswidthNumber按钮列宽度
chkBoolean是否开启多选 默认否
heightString设置表格高度 css
pagesizeNumber每页长度 默认20
pageindexNumber起始页 默认1
countNumber查询数据总量

列定义

cols:{//字段名name:{title:"姓名",//表头width:100//列宽},//字段名phone:{title:"手机号",//表头width:150,//列宽/*** 格式化数据* */fmt(v,r){return '+86 '+r.phone;}},
}

按钮


btns:[{text:"编辑",//按钮文字class:"btn1",//附加样式type:"primary",//uniapp提供的按钮类型 蓝色primary/红色warn//设置按钮状态,返回true按钮可用,false按钮不可用disabled(r){// r=当前行数据return r.phone.indexOf('15')>-1;},//按钮单击事件click(r){// r=当前行数据}}
]

方法

名称类型描述
trstyleFunction行样式,可以设置背景色或文字颜色来标记不同的数据状态,详细信息见下面行样式
chkchangeFunction选择事件,详细信息见下面选择事件
topageFunction翻页事件,详细信息见下面翻页事件

行样式

/**
* 判断数据状态,给行加上样式
**/
tablestyle(r){// r=当前行数据var style={style.background="#ff9999";};if(r.phone>17000000000){style.background="#ff66ff";}return style;
},

选择事件

chkchange(v){// v.detail.index 当前选中的所有行console.log(v)
},

翻页事件

topage(e){//e=当前页this.pageindex=e;//查询数据this.getdata();
},

使用组件


相关内容

热门资讯

廊坊银行鏖战“逆风局” 在中小银行股权拍卖热潮之下,廊坊银行正遭遇市场的“审视”。2月9日,北京金融法院即将上拍廊坊银行一笔...
对话 | 陈行甲:公益需要专业... 记者 刘亚宁 近日,公益领域知名人物、曾以“网红县委书记”为人所知的陈行甲,因其个人收入问题受到争议...
金星啤酒港股IPO闯关,中式精... 2026年1月13日,河南金星啤酒股份有限公司(下称“金星啤酒”)正式向香港联交所主板递交上市申请,...
原创 又... 一管尚未进入临床试验的药膏, 如何点燃股民热情? 作者丨姚悦 编辑丨于婞 来源 | 野马财经 开年以...
原创 麦... 最近年底了,要看明年的经济新趋势,其实早已奠定了!继续要促进内需消费!这个方向没有停止,那么也就意味...
“三九”天戴帽=护心脑 三九寒天,寒气刺骨,不少人裹紧大衣却忽略头部保暖。专家提醒,寒从“头”入非虚言,一顶帽子竟是护心脑的...
12天获数千万融资,高瓴、智元... 小米(01810.HK)原中国区市场部总经理王腾再次冲上热搜。 这一次,他的身份是今日宜休科技公司(...
耐克大中华区换帅,“Win N... 自推行“Win Now”战略以来,耐克高层变动频繁。这次轮到了大中华区。 1月21日,耐克公司宣布,...
和讯投顾王宇:拥抱趋势才是主流... 1月21日,和讯投顾王宇分析称,自从上周市场主动降温以来,就一直在对于商业航天和AI应用的修复预期要...
消息称马斯克希望在7月前完成S... 马斯克 北京时间1月21日,据《华尔街日报》报道,埃隆马斯克(Elon Musk)这些年来一直抵制让...
原创 今... 昨天,国际金价站上了4600美元一盎司,国内金店首饰价格直接飙到1300元一克。 很多人一看这价格就...
这种“静态”运动,降压效果竟排... 高血压作为一种常见的慢性疾病,已经成为威胁全球人类健康的重要杀手之一。据世界卫生组织统计,全球约有 ...
跨境ETF加速扩容,港股赛道成... 来源:21世纪经济报道 21世纪经济报道特约记者 庞华玮 今年1月12日,中国跨境ETF市场迎来历史...
贴牌工厂的IPO幻梦:宁波惠康... 当一家深耕ODM贴牌业务26年的企业,试图以“全球民用制冰机市占率第一”的龙头叙事冲击主板IPO,其...
突发!锂电材料龙头拟赴港上市! 本报记者 陈红 1月21日晚间,苏州天华新能源科技股份有限公司(以下简称“天华新能”,股票代码:30...
茅台联名冰淇淋卖不动了? 当茅台冰淇淋在便利店冰柜里积灰时,泸州老窖与《三体》联名的"黑暗森林"酒却创下10分钟售罄的纪录。这...
原创 中... 1月16日,俄罗斯《生意人报》刊发了一则震动全球的新闻:中俄之间历时14年的电力进口合作宣告终止。与...
去年前三季净利下滑近两成,奕帆... 深圳商报·读创客户端记者 张弛 1月21日,奕帆传动(301023.SZ)开盘即封住20%涨停,截至...
AI应用ETF的“故事”讲完了... 2026年开年,AI应用板块无疑是市场最瞩目的焦点之一,AI投资风向从算力基础设施向具体应用场景扩散...
银行应该承担房价下跌的损失吗? 最近看到一个观点,说是银行应该承担房价下跌的损失,因为大洋对岸的漂亮国就是这么做的, 在M国你可以主...