Vue实战:table组件(带搜索,排序)

一、效果

Vue实战:table组件(带搜索,排序)_第1张图片
Vue实战:table组件(带搜索,排序)_第2张图片

二、源码

index.html



    
    
    
    Document
    
    


    

排序功能实现思路:
点击引发页面渲染,要么@click,要么采用watch 或 computed, 考虑到以后的扩展性,选用computed(监视多个元素的变化)。我们用computed监听sortKey变量,当点击 表头(Name/Power)时,改变sortKey值,进而执行computed函数(函数主要逻辑:利用sort函数排序),页面重新渲染。这样我们就实现了一个方向的排序。

现在我们来实现table的正反排序:思路同但排序一样,用computed监听sortOrders变量({name: 1/-1,power: 1/-1}), 当点击 表头(Name/Power)时,不仅改变sortKey值,同时改变sortOrders变量(改变对应表头的正负值即可,正负值用来控制对应表头的正反排序),然后再在sort里做一些改变(改变值的正负)即可。

搜索功能实现思路:
基本同上,只是用到了Object.keys()、filter()等函数


./Vuetest.css
body {
  font-family: Helvetica Neue, Arial, sans-serif;
  font-size: 14px;
  color: #444;
}

table {
  border: 2px solid #42b983;
  border-radius: 3px;
  background-color: #fff;
}

th {
  background-color: #42b983;
  color: rgba(255,255,255,0.66);
  cursor: pointer;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
}

td {
  background-color: #f9f9f9;
}

th, td {
  min-width: 120px;
  padding: 10px 20px;
}

th.active {
  color: #fff;
}

th.active .arrow {
  opacity: 1;
}

.arrow {
  display: inline-block;
  vertical-align: middle;
  width: 0;
  height: 0;
  margin-left: 5px;
  opacity: 0.66;
}

.arrow.asc {
  border-left: 4px solid transparent;
  border-right: 4px solid transparent;
  border-bottom: 4px solid #fff;
}

.arrow.dsc {
  border-left: 4px solid transparent;
  border-right: 4px solid transparent;
  border-top: 4px solid #fff;
}

你可能感兴趣的:(web前端,Vue)