项目需求: 在文本框中填写序号,让显示的顺序根据序号的变换而更改。

效果图(用的blur触发事件,看起来不太舒服):

spring boot 排他 springboot 排序_spring boot 排他


图片中可以看到,当我删除序号后,会自动填充0.(在添加内容的时候没有序号这一项,添加完成后默认为空,为空后会在第一个显示)。当我把4改1后自动向上移动。

不足: 更改后是通过刷新页面来展示效果的,不圆润。触发方式不太合适。

代码介绍: 首先数据库中要有相应的字段来存储用来排序的字段。两种解决方案,一种是根据id进行单个字段的更改,更改后并按照该字段进行排序显示。另一种是使用全局的修改,先根据id查询出全部内容,在将更改后的序号替换原来的序号,其他字段使用查询出内容。第一种方法好理解,但是代码多。第二种理解起来想对第一种难一点,但是代码可以重复使用。里面因为需求原因,包含一些分页代码,但是不全面。需要的话我的其它文章中有详细介绍分页的(代码全面)

前端代码

<tr v-for="(ne,key) in news"><!-- news 是我查出全部数据后保存数据的数组(key是关键字,可以理解为数组的下标) -->
<td>
 	<input type="text"  
 	v-model="ne.px" v-on:blur="findSort(ne.nid,ne.px)" 
 	style="width: 25px; line-height: 17px; display: inline-block" />
 	<!-- 这里调用方法传的两个参数,第一个是内容的id;另一个是序号 -->
</td>
</tr>

这就是那个要输入序号的文本框,没什么需要注意的,就那个v-model的值px是数据库中的字段名

data:{
	news:[],
},
methods:{
	//排序	点击排序触发方法
		//方法需要获取id、更新后的序号	控制层:根据id修改要更改的字段,改且只改一个字段,其他字段禁止更改
	findSort:function(id,px){
		if(px==null || px==""){//如果px没有值,就给他赋值为0,避免保存
			px=0;
		}
		$.post("/news/sorts",{nid:id,px:px},function(data){
			//alert(data);
			window.location.href="/admin/news";//news方法是写在controller中查询全部数据的方法
		});
	},
}

controller代码

//排序,这里我用的是第一个方法,第二个没有测试,但是代码是那样写的
	@RequestMapping("sorts")
	@ResponseBody
	public String sorts(HttpServletRequest req) {
		String nid = req.getParameter("nid");
		String px = req.getParameter("px");
		if(px==null||px=="") {//在这里判断意义不大,但是还是加上好
			px="0";
		}
		newsServicel.sorts(nid, px);//service层代码下面有
		return "success";//返回值随意写,唯一的用处就是可以在js中判断一下是否执行了,意义不大
	}
	//排序方法二
	public String sort2(HttpServletRequest req) {
		String nid = req.getParameter("nid");
		String px = req.getParameter("px");
		if(px==null||px=="") {
			px="0";
		}
		News news = newsServicel.findId(nid);//findId是通过id查询所有的方法,代码就不单独贴出来了
		news.setNid(nid);
		news.setPx(px);
		newsServicel.save(news);//save是添加的方法
		return "succell";
	}
//排序完成后就是要显示了,下面代码就是根据px字段进行排序显示的
//这是分页的代码,如果不使用分页的话可以在sql语句中添加order by px ASC
@RequestMapping("findLikeTitle")
@ResponseBody
public Page<List<Map>> findLikeTitle(HttpServletRequest req) {
	//接收当前页
	Integer page = Integer.parseInt(req.getParameter("page"));
	//需要根据title、id进行迷糊查询
	String title = req.getParameter("title");
	String id = req.getParameter("id");
	Sort sort = null;
	//括号中出来“px”,其他都是关键字
	sort = new Sort(Sort.Direction.ASC, "px");
	//为了前端效果,页面显示是从1开始,但是分页默认是从0开始,所有这里page要-1.4是没页显示的条数,sort关键字
	Pageable pageable = PageRequest.of(page - 1, 4, sort);
	Page<List<Map>> data = newsServicel.findeLikeTitle(pageable, title, id);
	return data;
	}

service代码

//排序
@Transactional//别问为什么写这个注解,我只知道不写不对
public void sorts(String nid,String px){
	 newsDAO.sorts(nid,px);
}

//模糊查询、分页。
	public Page<List<Map>> findeLikeTitle(Pageable page,String title,String id){
		return newsDAO.findBytitleLike(page,"%"+title+"%","%"+id+"%");
	}

DAO层代码

//排序
@Query(value="update news set px = :px where nid=:nid",nativeQuery = true)//不使用分页查询可以在value中追加order by px ASC实现根据px排序
@Modifying//单个修改必须写的注解
void sorts(String nid,String px);


//分页模糊查询表连接
@Query(value="select * from news n join type t on n.t_id=t.tid where title like concat('%',:title,'%') and t_id like concat('%',:id,'%')",nativeQuery = true)
Page<List<Map>> findBytitleLike(Pageable page,String title,String id);

到这里排序就完成了。不足之处就是需要刷新以下页面才能查看到效果,不太圆润。还有什么不足之处,欢迎指正。