table 上移 下移 保存时 获取每行中的值 将排序记录保存到数据库

<%@ page language="java" pageEncoding="UTF-8"%>
<%
String path = request.getContextPath();
%>
<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
<title>应用之星后台管理</title>

<script type="text/javascript" src="<%=path %>/js/jquery-1.4.2.js"></script>
<script type="text/javascript">
var moveRow;
function checkNews(obj){
	moveRow = obj.parentNode;
	//alert(moveRow.innerHTML);
	var trs =  document.getElementById("DynaTable").rows;
	for(var i = 0 ;i<trs.length;i++){
		trs[i].cells[0].style.backgroundColor="red";
	};
	obj.style.backgroundColor='blue';
	
}
function check(oper){
	// var data_tr=$(t).parent().parent(); //获取到触发的tr
	var data_tr = moveRow
	if(oper=="MoveUp"){    //向上移动
		if($(data_tr).prev().html()==null){ //获取tr的前一个相同等级的元素是否为空
		    alert("已经是最顶部了!");
		    return;
		}
		$(data_tr).insertBefore($(data_tr).prev()); //将本身插入到目标tr的前面 
		
	}else{
	    if($(data_tr).next().html()==null){
	         alert("已经是最低部了!");
	         return;
	    }
	    $(data_tr).insertAfter($(data_tr).next()); //将本身插入到目标tr的后面 
	    
	}
}
function save(){
	var result ='';
	var trs =  document.getElementById("DynaTable").rows;
	for(var i = 0 ;i<trs.length;i++){
		result += trs[i].cells[0].firstChild.value+",";
	};
	alert("保存后的排序为:"+result);
}
</script>
</head>

<body>
<button οnclick="check('MoveUp')">上移</button><button οnclick="check('MoveDown')">下移</button><button οnclick="save()">保存</button>
<table id = "DynaTable">
	<tr>
		<td style="width: 300px;background-color: red" οnclick="checkNews(this)">
			<input type="hidden" name="newsId" value="1"></input>a
		</td>
	</tr>
	<tr>
		<td style="width: 300px;background-color: red" οnclick="checkNews(this)">
			<input type="hidden" name="newsId" value="2"></input>b
		</td>
	</tr>
	<tr>
		<td style="width: 300px;background-color: red" οnclick="checkNews(this)">
			<input type="hidden" name="newsId" value="3"></input>c
		</td>
	</tr>
</table>
</body>
</html>


a
b
c
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在Vue实现table行的上移下移,需要先在表格添加对应的操作按钮,然后在点击按钮调用接口进行数据的上移下移操作。具体实现步骤如下: 1. 在表格添加上移下移按钮,可使用element-ui的按钮组件: ``` <el-table-column label="操作"> <template slot-scope="scope"> <el-button type="text" icon="el-icon-arrow-up" @click="handleMoveUp(scope.row)">上移</el-button> <el-button type="text" icon="el-icon-arrow-down" @click="handleMoveDown(scope.row)">下移</el-button> </template> </el-table-column> ``` 2. 在methods定义handleMoveUp和handleMoveDown方法,分别调用接口进行数据上移下移操作: ``` methods: { // 上移操作 handleMoveUp(row) { const index = this.tableData.indexOf(row) if (index > 0) { // 调用上移接口 this.$axios.post('/api/moveUp', {id: row.id}).then(res => { this.tableData.splice(index, 1) this.tableData.splice(index - 1, 0, row) }) } }, // 下移操作 handleMoveDown(row) { const index = this.tableData.indexOf(row) if (index < this.tableData.length - 1) { // 调用下移接口 this.$axios.post('/api/moveDown', {id: row.id}).then(res => { this.tableData.splice(index, 1) this.tableData.splice(index + 1, 0, row) }) } } } ``` 3. 在接口实现数据上移下移操作,可使用数据库排序字段进行排序: ``` // 上移接口 app.post('/api/moveUp', (req, res) => { const id = req.body.id // 查询当前行和前一行的数据 const sql = `SELECT *, (SELECT sort FROM table WHERE id = ${id-1}) AS prevSort FROM table WHERE id = ${id}` connection.query(sql, (err, results) => { if (err) throw err // 如果当前行不是第一行,则进行上移操作 if (results[0].prevSort) { const prevSort = results[0].prevSort const currSort = results[0].sort // 交换当前行和前一行的排序字段 const sql1 = `UPDATE table SET sort = ${prevSort} WHERE id = ${id}` const sql2 = `UPDATE table SET sort = ${currSort} WHERE id = ${id-1}` connection.query(sql1, (err, results) => { if (err) throw err connection.query(sql2, (err, results) => { if (err) throw err res.json({code: 0, message: '移动成功'}) }) }) } else { res.json({code: -1, message: '当前行已经是第一行,无法上移'}) } }) }) // 下移接口 app.post('/api/moveDown', (req, res) => { const id = req.body.id // 查询当前行和后一行的数据 const sql = `SELECT *, (SELECT sort FROM table WHERE id = ${id+1}) AS nextSort FROM table WHERE id = ${id}` connection.query(sql, (err, results) => { if (err) throw err // 如果当前行不是最后一行,则进行下移操作 if (results[0].nextSort) { const nextSort = results[0].nextSort const currSort = results[0].sort // 交换当前行和后一行的排序字段 const sql1 = `UPDATE table SET sort = ${nextSort} WHERE id = ${id}` const sql2 = `UPDATE table SET sort = ${currSort} WHERE id = ${id+1}` connection.query(sql1, (err, results) => { if (err) throw err connection.query(sql2, (err, results) => { if (err) throw err res.json({code: 0, message: '移动成功'}) }) }) } else { res.json({code: -1, message: '当前行已经是最后一行,无法下移'}) } }) }) ``` 以上是基本的实现思路,具体实现过程需要根据实际业务进行调整。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值