侧边栏壁纸
  • 累计撰写 46 篇文章
  • 累计创建 38 个标签
  • 累计收到 2 条评论
隐藏侧边栏
VUE

Vue long精度丢失问题

哒卟刘先生
2022-06-02 / 0 评论 / 0 点赞 / 235 阅读 / 828 字 / 正在检测是否收录...
温馨提示:
本文最后更新于 2022-06-02,若内容或图片失效,请留言反馈。部分素材来自网络,若不小心影响到您的利益,请联系我们删除。

原因

vue前端对long类型的精度无法接收,javascript 的 Number 类型最大长度是17位,
mysql 使用bigint 类型长度是20位。

前端解决方法:

在全局的网络请求 用了一个处理数据的插件 来转换
在这里插入图片描述

后端解决的方法

@Configuration
@EnableWebMvc
public class CustomJsonConfiguration implements WebMvcConfigurer {
    @Override
    public void configureMessageConverters(List<HttpMessageConverter<?>> converters) {
        MappingJackson2HttpMessageConverter jackson2HttpMessageConverter = new MappingJackson2HttpMessageConverter();
 
        ObjectMapper objectMapper = new ObjectMapper();
       
        SimpleModule simpleModule = new SimpleModule();
        simpleModule.addSerializer(Long.class, ToStringSerializer.instance);
        simpleModule.addSerializer(Long.TYPE, ToStringSerializer.instance);
        objectMapper.registerModule(simpleModule);
 
        jackson2HttpMessageConverter.setObjectMapper(objectMapper);
        converters.add(jackson2HttpMessageConverter);
    }
}

原文链接:https://blog.csdn.net/DamonREN/article/details/124268642
0

评论区