有些时候,我们总是无可避免的需要自己去手撸一些东西,因为需求总是在不断的变化。例如,最开始的需求,我们只是在首页展示一个数据列表,此时,我们可能直接就自己手写了一个table,后来,突然增加了一个需求,例如:需要在一些指定的列上面增加排序功能。此时,由于我们的样式和界面都已经调整好了,如果再去重新使用第三方的一些vue组件,会觉得没必要浪费时间,于是,很可能,就需要自己动手去增加一个这样的功能。如下图所示:

  

  封装的组件“DataTable.vue”,代码如下:

<template>
<table class="table">
<thead>
<tr>
<th>{{title}}</th>
<th v-if="title!='建筑'"
@click="onClickHead('count',0)">项目总数(个)<i v-if="filed=='count'"
:class="getIcon(0)"></i></th>
<th @click="onClickHead('objArea',1)">总面积(㎡)<i v-if="filed=='objArea'"
:class="getIcon(1)"></i></th>
<th @click="onClickHead('objEnergy',2)">今日总用电(kWh)<i v-if="filed=='objEnergy'"
:class="getIcon(2)"></i></th>
<th @click="onClickHead('objAreaEnergy',3)">能耗密度(kWh/㎡)<i v-if="filed=='objAreaEnergy'"
:class="getIcon(3)"></i></th>
<th @click="onClickHead('personEnergy',4)">人均能耗(kWh/人)<i v-if="filed=='personEnergy'"
:class="getIcon(4)"></i></th>
</tr>
</thead>
<tbody>
<tr v-for="(item,index) in filterData"
:key="index"
:class="{'default':title=='建筑'}"
@click="jumpToDistrict(item)">
<td>{{item.objName}}</td>
<td v-if="title!='建筑'">{{item.count}}</td>
<td>{{item.objArea}}</td>
<td>{{item.objEnergy}}</td>
<td>{{item.objAreaEnergy}}</td>
<td>{{item.personEnergy}}</td>
</tr>
</tbody>
</table>
</template> <script>
export default {
props: {
title: {
type: String,
default: '区域'
},
dataList: {
type: Array,
default: () => {
return []
}
}
},
data () {
return {
filed: 'count', //排序字段-当前
arrOrderAsc: [false, true, true, true, true], //默认第一项降序
curCellIndex: 0, //当前排序列索引
filterData: []
}
},
watch: {
dataList: {
handler: function (val) {
if (val && val.length > 0) {
this.getOrderData();
}
},
immediate:true,
deep: true, //深度监听设置为 true
}
},
methods: {
getOrderData () {
let list = this.dataList.map(m => {
return {
objName: m.objName,
count: m.regionsList ? m.regionsList.length : 0,
objArea: m.objArea,
objEnergy: m.objEnergy,
objAreaEnergy: m.objAreaEnergy,
personEnergy: m.personEnergy
}
});
this.filterData = this.arrOrderAsc[this.curCellIndex] ? list.sort(this.compareAsc(this.filed)) : list.sort(this.compareDesc(this.filed));
},
jumpToDistrict (item) {
console.log('item :>> ', item);
if (this.title == '建筑') return;
this.$emit('jumpToDistrict', { id: item.objId, name: item.objName, regionsList: m.regionsList });
},
//升序--这是比较函数
compareAsc (p) {
return function (m, n) {
var a = m[p];
var b = n[p];
return a - b;
}
},
//降序--这是比较函数
compareDesc (p) {
return function (m, n) {
var a = m[p];
var b = n[p];
return b - a;
}
},
//点击排序列
onClickHead (val, index) {
this.filed = val;
this.curCellIndex = index;
this.arrOrderAsc[index] = !this.arrOrderAsc[index];
this.getOrderData();
},
//获取升降序图标
getIcon (index) {
return this.arrOrderAsc[index] ? 'el-icon-caret-top' : 'el-icon-caret-bottom';
}
}
}
</script> <style lang="scss" scoped>
@import "@/assets/css/variables.scss";
table thead,
tbody tr,
tfoot tr {
display: table;
width: 100%;
table-layout: fixed;
text-align: center;
}
.table {
width: 100%;
border-collapse: collapse;
text-align: center;
color: white;
tr {
height: 28px;
line-height: 28px;
}
thead {
background: rgba(97, 160, 236, 0.12);
cursor: pointer;
}
tbody {
display: block;
height: 150px;
overflow-y: auto;
@include scrollbarHomeV;
background: linear-gradient(
180deg,
rgba(19, 34, 98, 0.6) 0%,
ragb(9, 22, 56, 0.6) 100%
);
tr {
cursor: pointer;
&:hover {
color: #26c8f6;
background: rgba(40, 54, 77, 0.5);
}
&.default {
cursor: default;
}
}
}
caption {
text-align: left;
padding-bottom: 4px;
}
}
</style>
公共样式代码variables.scss,此处主要是自定义滚动样式
$headHeight:80px;//导航条高度
$mainBgColor:#081338; //主体背景颜色
$scrollbarColorHome:#135786; //首页滚动条样式
$hoverColor: #7abef9; //链接hover颜色
/*-----------------------------首页定义滚动条样式------------------*/
@mixin scrollbarHomeV($w: 10px, $h: 12px) { /*webkit内核*/
&::-webkit-scrollbar {
width: $w;
/*滚动条宽度*/
height: $h;
/*滚动条高度*/
} &::-webkit-scrollbar-track {
-webkit-box-shadow: inset 0 0 6px rgba(19, 87, 134, 0.1);
border-radius: 6px;
} &::-webkit-scrollbar-thumb {
border-radius: 6px;
background: $scrollbarColorHome;
-webkit-box-shadow: inset 0 0 6px rgba(19, 87, 134, 0.5);
min-height: 40px; &:hover {
background: $scrollbarColorHome;
}
} &::-webkit-scrollbar-thumb:window-inactive {
background: $scrollbarColorHome;
}
}

vue中手写table的升降序的更多相关文章

  1. OA系统中手写签批功能的实现

    一.需求背景 OA系统审批中,有对word或者pdf文件源文档在指定的位置可以插入相应的文字,其实就是一个审批的功能,到了指定的人那边,他可以进行签批.这个功能一般来说,是针对于领导方面,对于一个事情 ...

  2. 基于vue框架手写一个notify插件,实现通知功能

    简单编写一个vue插件,当点击时触发notify插件,dom中出现相应内容并且在相应时间之后清除,我们可以在根组件中设定通知内容和延迟消失时间. 1. 基础知识 我们首先初始化一个vue项目,删除不需 ...

  3. vue中,写在methods里的B方法去调A方法的数据,访问不到?

    今天在写项目的时候,发现了一个京城性忽略的问题,在vue的methods的方法里面定义了两个方法,如下: getTaskList() { api.growthDetails.taskList({ ap ...

  4. vue中获取滚动table的可视页面宽度,调整表头与列对齐(每列宽度不都相同)

    mounted() { // 在mounted中监听表格scroll事件 this.$refs.scrollTable.addEventListener( 'scroll',(event) => ...

  5. vue中指令写了一个demo

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  6. html 中手写阴影弹窗框封装

    // 弹出提示框 function popup(pWidth,content) { $("#msg").remove(); var html ='<div id=" ...

  7. vue js 手写 正则判断 手机号码 和 密码

    const phoneOrEmails = /^1[3|4|5|6|7|8|9][0-9]\d{8}$/             if(this.ruleForms.phoneOrEmail  ==  ...

  8. Atiit 如何手写词法解析器

    Atiit 如何手写词法解析器 1.1. 通过编程直接从正则->nfa->dfa->表驱动词法解析一条龙自动生成.那是用程序自动生成是需要这样的,自己手写完全不必要这么复杂1 1.2 ...

  9. vue中修改swiper样式

    问题 vue单文件组件中无法修改swiper样式. 解决 1,单文件组件中:新增一个style 不加scoped 让它最终成为全局样式.只在其中操作swiper的样式. <style lang= ...

  10. 实战技巧,Vue原来还可以这样写

    hookEvent,原来可以这样监听组件生命周期 1. 内部监听生命周期函数 <template> <div class="echarts"></di ...

随机推荐

  1. Java Spring项目中的CORS跨域开启的几种方式

    引 在服务器端开启跨域的原理,一般都是通过在HTTP Headers中的响应头的Access-Control-Allow-Origin指定放行的域,来完成的. Access-Control-Allow ...

  2. keil 中未编译的代码灰色显示

    一.转载文章 转载:KEIL,#ifdef宏定义下失效代码差异性显示 注意keil的版本,太低的版本不具备灰色显示,据我所知在KEIL uVersion V5.31版本以上均可以. 二.使能灰色显示 ...

  3. HTTP 结构概述

    Web 客户端和服务器 Web 内容都是存储在 Web 服务器上的,Web 服务器所使用的是 HTTP 协议,因此经常被称为 HTTP 服务器,HTTP 服务器存储了因特网的数据.客户端向服务器发送 ...

  4. ES6常用知识点笔记

    ECMAScript 6(以下简称ES6)是JavaScript语言的下一代标准. 因为当前版本的ES6是在2015年发布的,所以又称ECMAScript 2015(简称ES2015).虽然浏览器在不 ...

  5. 用 C 语言开发一门编程语言 — 变量元素设计

    目录 文章目录 目录 前文列表 变量 变量语法规则 变量的读取和存储 将变量加入 Lisp Value 体系 变量的计算 变量的定义与赋值 异常处理优化 源代码 前文列表 <用 C 语言开发一门 ...

  6. 我开源的H5商城2.0版本发布,强烈推荐

    简介 waynboot-mall 是一套全部开源的 H5 商城项目,包含运营后台.H5 商城前台和后端接口三个项目 .实现了一套完整的商城业务,有首页展示.商品分类.商品详情.sku 详情.商品搜索. ...

  7. 未能加载文件或程序集“UFIDA.U8.UAP.GcRegister, Version=1.0.0.0, Culture=neutral, PublicKeyToken=null”或它的某一个依赖项

    这是做采购入库单新增的时候遇到的问题,我是采用模仿写用友u8的zpurrkdhead 主表视图和子表视图zpurrkdtail 去构建 xml文档这样做的,但是再做的时候 [cgcroutecode] ...

  8. JDK动态代理的深入理解

    引入代理模式 代理模式是框架中经常使用的一种模式,动态代理是AOP(面向切面编程)思想的一种重要的实现方式,在我们常用的框架中也经常遇见代理模式的身影,例如在Spring中事务管理就运用了动态代理,它 ...

  9. .NET6之MiniAPI(九):基于角色的身份验证和授权

    身份验证是这样一个过程:由用户提供凭据,然后将其与存储在操作系统.数据库.应用或资源中的凭据进行比较. 在授权过程中,如果凭据匹配,则用户身份验证成功,可执行已向其授权的操作. 授权指判断允许用户执行 ...

  10. NOIP模拟56

    前言 话说, T2 和 T3 的题面好像放反了. T1 爆零 解题思路 是个原题.. 当时 WindZR 25分钟就码完了,然后我就慌死,写完就开始调,诶,我当时场上不是切了吗,怎么现在打不对了.. ...