layui-vue + Flask 实现 Table 排序显示

layui-vue + Flask 实现 Table 排序显示

在编写使用 Vue + layui 的中后台系统时,table页面通常是必不可少的。要在 Vue 中实现基于某一列的排序,我们需要更新 columns 数组中相应列的定义,以便包含排序的逻辑。

举例:在代码中,我希望基于 "类型" 这一列进行排序。则可以通过添加一个 sortable: true 属性来实现这一点。

javascript 复制代码
const columns = [
  // ... 其他列的定义
  {
    title: '类型',
    width: '180px',
    customSlot: 'type',
    key: 'type',
    sortable: true // 添加此属性以启用排序
  },
  // ... 其他列的定义
]

此外,还需要在 lay-table 组件中处理排序事件。为此,可以修改 change 方法以包含对排序参数的响应。

javascript 复制代码
const change = ({ current, limit, sort }: any) => {
  if (sort) {
    // 如果存在排序信息,则按照排序信息获取数据
    // sort.field 是排序字段,sort.order 是排序顺序('asc' 或 'desc')
    queryDataWithSort(sort.field, sort.order);
  } else {
    // 正常的分页逻辑
    layer.msg('current:' + current + ' limit:' + limit)
  }
}

const queryDataWithSort = (field, order) => {
  // 实现您的排序逻辑,例如调用 API 获取排序后的数据
  // 模拟的 API 调用示例
  queryAllDataSortedBy(field, order).then(res => {
    dataSource.value = res.data;
  }).catch(err => console.log(err));
}

API 实现

要实现一个 queryAllDataSortedBy API,我们需要在后端设置一个能够接收排序参数并根据这些参数返回排序后数据的接口。以下是一个基本的实现步骤指南,分为前端和后端部分。

前端实现

Vue 前端,我们需要创建一个函数,它会向后端发送一个包含排序参数的请求。这个函数将接收排序字段(field )和排序顺序(order ),然后使用这些参数构造一个请求。假设使用 Axios 进行 HTTP 请求,如下所示:

javascript 复制代码
import axios from 'axios';

const queryAllDataSortedBy = async (field, order) => {
  try {
    const response = await axios.get('/api/data', {
      params: {
        sortField: field,
        sortOrder: order
      }
    });
    return response.data;
  } catch (error) {
    console.error('Error fetching sorted data:', error);
    throw error;
  }
};

后端实现

使用 FlaskSQLite,我们可以创建一个简单的后端服务来处理带有排序参数的请求,并根据这些参数返回排序后的数据。以下是一个实现的示例:

python 复制代码
from flask import Flask, request, jsonify
import sqlite3

app = Flask(__name__)

def get_sorted_data(sort_field, sort_order):
    # 连接到 SQLite 数据库
    conn = sqlite3.connect('example.db')
    cursor = conn.cursor()

    # 安全地构建查询,避免 SQL 注入风险
    # 由于 SQLite 的参数化查询不支持列名和排序方向,这里需要进行一些验证
    valid_sort_fields = ['column1', 'column2', 'column3']  # 替换为您的列名
    valid_sort_orders = ['ASC', 'DESC']

    if sort_field not in valid_sort_fields:
        sort_field = 'column1'  # 默认排序字段
    if sort_order.upper() not in valid_sort_orders:
        sort_order = 'ASC'  # 默认排序方向

    # 执行查询
    query = f"SELECT * FROM your_table ORDER BY {sort_field} {sort_order}"
    cursor.execute(query)
    results = cursor.fetchall()

    cursor.close()
    conn.close()
    return results

@app.route('/api/data', methods=['GET'])
def data():
    sort_field = request.args.get('sortField', default='column1', type=str)
    sort_order = request.args.get('sortOrder', default='ASC', type=str)
    
    sorted_data = get_sorted_data(sort_field, sort_order)
    return jsonify(sorted_data)

if __name__ == '__main__':
    app.run(debug=True)
相关推荐
不悔哥4 分钟前
vue 案例使用
前端·javascript·vue.js
工业互联网专业13 分钟前
毕业设计选题:基于ssm+vue+uniapp的捷邻小程序
vue.js·小程序·uni-app·毕业设计·ssm·源码·课程设计
陈无左耳、28 分钟前
Vue.js 与后端配合:打造强大的现代 Web 应用
vue.js
anyup_前端梦工厂34 分钟前
Vuex 入门与实战
前端·javascript·vue.js
你挚爱的强哥1 小时前
【sgCreateCallAPIFunctionParam】自定义小工具:敏捷开发→调用接口方法参数生成工具
前端·javascript·vue.js
喝旺仔la1 小时前
Element 表格相关操作
javascript·vue.js·elementui
繁依Fanyi1 小时前
使用 Spring Boot + Redis + Vue 实现动态路由加载页面
开发语言·vue.js·pytorch·spring boot·redis·python·算法
米老鼠的摩托车日记1 小时前
【vue element-ui】关于删除按钮的提示框,可一键复制
前端·javascript·vue.js
forwardMyLife1 小时前
element-plus的菜单组件el-menu
javascript·vue.js·elementui
pan_junbiao2 小时前
Vue使用代理方式解决跨域问题
前端·javascript·vue.js