当前位置: 首页 > wzjs >正文

做响应式网站是不是都用rem抖音推广平台联系方式

做响应式网站是不是都用rem,抖音推广平台联系方式,佛山顺德容桂网站制作,凡科互动游戏怎么玩高分博主介绍:✌全网粉丝22W,CSDN博客专家、Java领域优质创作者,掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java技术领域✌ 技术范围:SpringBoot、SpringCloud、Vue、SSM、HTML、Nodejs、Python、MySQL、PostgreSQL、大数据、物…

博主介绍:✌全网粉丝22W+,CSDN博客专家、Java领域优质创作者,掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java技术领域✌

技术范围:SpringBoot、SpringCloud、Vue、SSM、HTML、Nodejs、Python、MySQL、PostgreSQL、大数据、物联网、机器学习等设计与开发。

感兴趣的可以先关注收藏起来,在工作中、生活上等遇到相关问题都可以给我留言咨询,希望帮助更多的人。

Spring Boot 返回排序后的 Map 但前端接收顺序不对的解决方案

  • 一、背景描述
  • 二、问题原因
  • 三、解决方案
    • 3.1 方案1:使用有序集合代替 Map(推荐)
    • 3.2 方案2:使用自定义对象包装
    • 3.3 方案3:确保使用正确的 Map 实现类
    • 3.4 方案4:前端处理方案
  • 四、最佳实践建议
  • 五、拓展:为什么LinkedHashMap有时也不起作用?

一、背景描述

返回给页面的VO中有一个List和一个Map,两个属性,而且都需要排序后返回,现象是List排序结果在页面中显示正常,而Map排序结果在页面中显示跟在服务器中排序后的不同。这就奇了怪了,明明是处理好排序后才返回给页面的,但是页面接收后就顺序不一致了。

二、问题原因

  • Map 的实现类问题:即使你使用了 LinkedHashMap 保持顺序,在 JSON 序列化过程中可能会丢失顺序
  • JSON 规范:标准的 JSON 对象本身是无序的键值对集合
  • 前端处理:JavaScript 的 JSON.parse() 默认不保证对象属性的顺序

三、解决方案

3.1 方案1:使用有序集合代替 Map(推荐)

@GetMapping("/sorted-data")
public ResponseEntity<List<Map.Entry<String, Object>>> getSortedData() {Map<String, Object> data = new LinkedHashMap<>();// 添加数据并排序data.put("A", 1);data.put("B", 2);data.put("C", 3);// 转换为保持顺序的Entry列表List<Map.Entry<String, Object>> sortedList = new ArrayList<>(data.entrySet());return ResponseEntity.ok(sortedList);
}

前端将收到类似这样的结构:

[{"key": "A", "value": 1},{"key": "B", "value": 2},{"key": "C", "value": 3}
]

3.2 方案2:使用自定义对象包装

@Data // Lombok 注解
public class KeyValuePair {private String key;private Object value;// 构造方法
}@GetMapping("/sorted-data")
public ResponseEntity<List<KeyValuePair>> getSortedData() {Map<String, Object> data = new LinkedHashMap<>();// 添加数据data.put("A", 1);data.put("B", 2);data.put("C", 3);// 转换为KeyValuePair列表List<KeyValuePair> result = data.entrySet().stream().map(e -> new KeyValuePair(e.getKey(), e.getValue())).collect(Collectors.toList());return ResponseEntity.ok(result);
}

3.3 方案3:确保使用正确的 Map 实现类

@GetMapping("/sorted-data")
public ResponseEntity<Map<String, Object>> getSortedData() {// 使用LinkedHashMap保持插入顺序Map<String, Object> data = new LinkedHashMap<>();// 添加数据(已排序)data.put("A", 1);data.put("B", 2);data.put("C", 3);// 配置Jackson保留Map顺序ObjectMapper mapper = new ObjectMapper();mapper.enable(SerializationFeature.INDENT_OUTPUT);mapper.configure(MapperFeature.SORT_PROPERTIES_ALPHABETICALLY, false);return ResponseEntity.ok(data);
}

3.4 方案4:前端处理方案

如果必须返回 Map,可以在前端处理:

// 假设后端返回的是保持顺序的LinkedHashMap序列化的JSON
fetch('/api/sorted-data').then(response => response.json()).then(data => {// 转换为数组保持顺序const sortedArray = Object.entries(data);console.log(sortedArray); // 这会保持顺序});

四、最佳实践建议

  1. 推荐使用方案1或方案2:返回 List<Entry>List<自定义对象> 是最可靠的方式
  2. 避免依赖JSON对象的属性顺序:这是不符合JSON规范的
  3. 如果需要严格顺序:可以在数据结构中包含顺序字段
@Data
public class OrderedItem {private int order;private String key;private Object value;// 构造方法
}@GetMapping("/sorted-data")
public ResponseEntity<List<OrderedItem>> getSortedData() {// 实现...
}

五、拓展:为什么LinkedHashMap有时也不起作用?

即使在Java端使用了LinkedHashMap,以下情况仍可能导致顺序丢失:

  1. 某些JSON库可能不保留Map顺序
  2. 前端JavaScript引擎对对象属性的处理
  3. 中间件(如网关、代理)可能重新序列化JSON

因此,使用有序的列表结构是最可靠的跨平台解决方案。


好了,今天分享到这里。希望你喜欢这次的探索之旅!不要忘记 “点赞” 和 “关注” 哦,我们下次见!🎈

本文完结!

祝各位大佬和小伙伴身体健康,万事如意,发财暴富,扫下方二维码与我一起交流!!!在这里插入图片描述

http://www.dtcms.com/wzjs/267250.html

相关文章:

  • 太原网页设计培训学校秦洁婷seo博客
  • 合肥网站建设公司排名sem优化师
  • 帮客户做网站图片被告侵权百度刷排名seo软件
  • 曲靖做网站的公司每日关键词搜索排行
  • 一品威客网靠谱吗北京搜索引擎优化主管
  • 郓城网站建设苏州seo网络推广
  • 怎么做一种网站为别人宣传搜索引擎排名机制
  • 手机做网站价格广告公司营销策划方案
  • 宁波搭建网站公百度自然搜索排名优化
  • 集团公司门户网站建设360竞价推广开户多少钱
  • 静态企业网站模板推广方案100个
  • 课题网站建设培训简讯地推拉新app推广接单平台免费
  • 地方房产网站APP如何做西安百度百科
  • 烟台中企动力提供网站建设网站模板大全
  • 深圳网站建设968怎么做网络销售
  • 网站备案 四川做网站用哪个软件
  • 写作文网站掉发脱发严重是什么原因
  • 做网站域名大概多少钱画质优化app下载
  • 郑州市疫情防控新闻发布会河北网站seo策划
  • 本地的佛山网站建设软文广告300字范文
  • 哪个网站可以帮人做ppt百度搜索下载app
  • 延吉网站开发公司惠州seo排名
  • 商业网页设计培训整站优化多少钱
  • 黑帽seo论坛官网seo优化找哪家做
  • 做彩票网站推广犯法吗seo教学网seo
  • 网站 建设 成品博客网站登录入口
  • 织梦dedecms教育培训网站模板(内多个插件含测试数据)关键词seo报价
  • 视频号排名优化帝搜软件四川seo技术培训
  • 网站建设及推广方案ppt模板精准信息预测
  • 做网站推广优化靠谱网站搜索引擎优化案例