在最近的工作中,遇到一个问题,个人所做的简历模块中有两个字段,分别是个人信息中的户口所在地和现居住城市。

前端界面中这两个选项框是用到了二级和三级联动,在向后端传输时希望可以通过数组类型进行传输,例如【000000,000001】

前端页面展示如下:

后台数据库实体类字段设计如下:

registered_residence    户口所在地    varchar(50)

current_city   现居住城市    varchar(50)

简历实体字段设计如下:

//户口所在地

private String registeredResidence;

//现居住城市

private String currentCity;

当选择完户口所在地一栏的省外,就会联动出现省下面对应的市,产生联动效果

在协商传输类型时产生疑问:

1.后端数据库中所定义的这两个类型为String类型

2.前台要求后端存入数组类型

拟定解决方案

一:在Java实体类中创建VO类来新建数据类型为数组类型,此变量用来接收数组,如下:

新增简历个人信息时,前端传入户口所在地和现居住城市,后端需按数组类型接收

否则会报错(数据类型不匹配)

在新增简历个人信息的时候需要按照数组接收,存入数据库后按照字符串存储

所以需要循环拆分,之后在拼接成字符串,然后再存入字符串

/**
* 更新简历个人信息(新增&&修改)
*/
@PutMapping("/updateBrief")
public ResponseEntity updateBrief(@RequestBody BriefVo briefVo){
System.out.println("briefVo:" + briefVo);
Brief brief = new Brief();
BeanUtils.copyProperties(briefVo,brief);
StringBuilder registeredResidence = new StringBuilder();
if(briefVo.getCurrentCitys().length > 0){
for(int i = 0;i<briefVo.getRegisteredResidences().length;i++){
registeredResidence.append(briefVo.getRegisteredResidences()[i]);
if(briefVo.getRegisteredResidences().length - i > 1){
registeredResidence.append("-");
}

}
}
String registeredResidence1 = registeredResidence.toString();
brief.setRegisteredResidence(registeredResidence1);

StringBuilder currentCity = new StringBuilder();
if(briefVo.getCurrentCitys().length > 0){
for(int i = 0;i<briefVo.getCurrentCitys().length;i++){
currentCity.append(briefVo.getCurrentCitys()[i]);
if(briefVo.getCurrentCitys().length- i > 1){
currentCity.append("-");
}
}
}
String currentCity1 = currentCity.toString();
brief.setCurrentCity(currentCity1);

String result = briefService.updateBrief(brief);
return ResponseEntity.ok(result);
}

=====================================================

在存入数据库后,数据库中的字段类型为String

再次查看的时候,还需要把字符串类型的数据变为数组传输到

前端进行交互,否则也会报新增时数据类型不匹配的错误

/**
* 查看简历所有信息(点击查看按钮时显示)
*/
@GetMapping("/findAllCus")
public BriefVo find(Brief brief) {
String briefId = brief.getBriefId();
List<BriefEduExperience> eduExperienceList = eduExperienceService.findEduExperienceByBriefId(briefId);
List<BriefWorkExperience> workExperienceList = workExperienceService.findWorkExpericeByBriefId(briefId);
List<BriefProjectExperience> projectExperienceList = projectExperienceService.findProjectExperienceByBriefId(briefId);
List<BriefTrainExperience> trainExperienceList = trainExperienceService.findTrainExpericeByBriefId(briefId);
List<BriefProSkill> proSkillList = proSkillService.findProSkillByBriefId(briefId);
BriefVo briefVo = new BriefVo();
BeanUtils.copyProperties(brief, briefVo);
briefVo.setEduExperienceList(eduExperienceList);
briefVo.setWorkExperienceList(workExperienceList);
briefVo.setProjectExperienceList(projectExperienceList);
briefVo.setTrainExperienceList(trainExperienceList);
briefVo.setProSkillList(proSkillList);
String registeredResidence = brief.getRegisteredResidence();
String[] registeredResidences = registeredResidence.split("-");
String currentCity = brief.getCurrentCity();
String[] currentCitys = currentCity.split("-");
briefVo.setCurrentCitys(currentCitys);
briefVo.setRegisteredResidences(registeredResidences);
return briefVo;
}

=====================================

在完成这步操作之后,又出现了问题,具体问题记不得太清了,小白请包涵

综上,一系列操作之后发现,后端实现起来比较复杂,需要多次循环,

所以为提高效率,决定让前端来传字符串,为接收存储都方便,

如有更好的解决方案,请指教!!!!!!

希望看到这篇博客的博友可以提供解决方案,欢迎交流分享!!!!!!

前端页面多级联动传输数据类型问题(数组or字符串)后端处理的更多相关文章

  1. HTML前端技术(JS的使用,包括数组和字符串)

    <script type="text/javascript"> /* JS 数组的操作 //concat 连接两个或更多的数组,并返回结果. var arr1 = ne ...

  2. JavaWeb开发使用jsp还是html做前端页面

    一.概述 刚开始学习Javaweb开发的小伙伴都有一个疑惑:用jsp开发前端还是用HTML开发前端呢? 这个疑惑的来源主要是:刚接触完前端但又不深入学习js,接着学习jsp,发现老师们都一直用着jsp ...

  3. JavaScript 多级联动浮动(下拉)菜单 (第二版)

    JavaScript 多级联动浮动(下拉)菜单 (第二版)   上一个版本(第一版请看这里)基本实现了多级联动和浮动菜单的功能,但效果不是太好,使用麻烦还有些bug,实用性不高.这次除了修改已发现的问 ...

  4. 微信小程序-多级联动

    微信小程序中的多级联动 这里用到的案例是城市选择器 先上代码: .wxml <view class="{{boxHide}}"> <view>{{nian} ...

  5. [ PHP+jQuery ] ajax 多级联动菜单的应用:电商网站的用户地址选择功能 ( 二 ) - 仿亚马逊下拉面板

    /** jQuery version: 1.8.3 Author: 小dee Date: 2014.11.8 */ 接上一篇博客. 实现带缓存的仿亚马逊下拉面板 效果图: 图1 初始 图2 点击省份 ...

  6. jQuery插件——多级联动菜单

    jQuery插件——多级联动菜单 引言 开发中,有好多地方用到联动菜单,以前每次遇到联动菜单的时候都去重新写,代码重用率很低,前几天又遇到联动菜单的问题,总结了下,发现可以开发一个联动菜单的功能,以后 ...

  7. MVC实现多级联动

    前言 多级联动(省级联动)的效果,网上现成的都有很多,各种JS实现,Jquery实现等等,今天我们要讲的是在MVC里面,如何更方便.更轻量的实现省级联动呢? 实现效果如下: 具体实现 如图所示,在HT ...

  8. 电商门户网站商品品类多级联动SpringBoot+Thymeleaf实现

    在淘宝.京东等电商网站,其门户网站都有一个商品品类的多级联动,鼠标移动,就显示,因为前端不是我做的,所以不说明前端实现,只介绍后端实现. 搭建部署SpringBoot环境 配置文件配置: 开启了对Th ...

  9. js 多级联动(省、市、区)

      js 多级联动(省.市.区) CreateTime--2018年4月9日17:10:38 Author:Marydon 方式一: 数据从数据库获取,ajax实现局部刷新 方式二: 数据从json文 ...

随机推荐

  1. hdu 1166 线段树 奇兵布阵

    #include<iostream> using namespace std; ; )*];//n个叶子就有2*n-4*n个节点 ]; int n; void getup(int root ...

  2. 安装两个版本的python安装包,后安装的python程序打开时闪退

    1.环境变量的问题 (Win7)右键打开“计算机”的属性设置→高级系统设置→环境变量.  在系统变量中的path中,编辑,在末尾加入Python的安装路径“F:\Python27”, 路径与路径之间使 ...

  3. Python3并发写文件

    使用python2在进行并发写的时候,发现文件会乱掉,就是某一行中间会插入其他行的内容. 但是在使用python3进行并发写的时候,无论是多进程,还是多线程,都没有出现这个问题,难道是python3的 ...

  4. 在Excel中,已知身份证号码,如何批量计算其实际年龄?

    昨天,上司问我:..,你会在Excel中计算年龄吗?当时,一下促住了.说真的,还真不会.今天研究了一下,写下来,方便日后查看. 首先,得有一张已知姓名和相应身份证号的原表吧. 在这张表上再加上三列:出 ...

  5. ACCESS_ONCE的作用

    如果你看过 Linux 内核中的 RCU 的实现,你应该注意到了这个叫做 ACCESS_ONCE() 宏. ACCESS_ONCE的定义如下: #define __ACCESS_ONCE(x) ({ ...

  6. adb shell am start -W查看APP启动时间(优化冷启动)

    ThisTime:最后一个启动的Activity的启动耗时: TotalTime:自己的所有Activity的启动耗时: WaitTime::ActivityManagerService启动App的A ...

  7. etcd安全集群三节点扩容至四个节点

    规划:先安装三台组建集群,然后扩容一个安全节点进来 .环境: 三台centos7. 主机 192.168.0.91 192.168.0.92 192.168.0.93 都关闭防火墙 都关闭selinu ...

  8. 【Web】[原创]ie6,7中td和img之间有间隙

    情形描述 开发工具:VS2010: 浏览器版本:IE6以上,火狐,谷歌: 页面布局设计:Table+Img布局: 项目预览问题:火狐,谷歌,IE8以上未出现问题,IE6,IE7图片之间有间隙. 分析原 ...

  9. 差分+贪心:IncDec序列

    原题 题目描述给定一个长度为 n 的数列 a1,a2,…,ana1,a2,…,an,每次可以选择一个区间 [l,r][l,r],使下标在这个区间内的数都加一或者都减一. 求至少需要多少次操作才能使数列 ...

  10. ctf网址,工具 汇总 组会

    @双系统装kali,专门渗透的,ubantu要自己下工具,但是娱乐性比较好 @做题 i春秋 https://www.ichunqiu.com/battalion @网站 xctf近期赛事https:/ ...