当前位置:首页 > 技术 > 正文内容

Spring MVC JSON响应与Vue事件绑定实践

访客 技术 2026年6月27日 2

Vue开发环境配置问题

在使用IDEA开发Vue项目时,可能会遇到标签智能提示不完整的情况。部分开发者环境中仅能识别基础指令如v-bind,而缺少完整的标签库支持。建议检查IDE的Vue插件安装状态及版本兼容性。

Vue项目进程管理

通过命令行启动的Vue开发服务器,终止服务的标准操作为组合键Ctrl+C。执行后终端会显示终止确认信息,释放占用的端口资源。

IDEA自定义HTML标签处理

当IDE提示"Add element to custom HTML tags"时,表示编辑器无法识别当前标签。若误操作添加了错误标签,可通过以下路径移除:

Settings → Editor → Inspections → HTML → Unknown HTML tag,在Custom HTML tags列表中删除对应条目。

Spring MVC返回复杂数据类型

Controller方法返回实体类、对象或集合时,需借助Jackson库实现Java对象到JSON的自动转换。

依赖配置

pom.xml中添加Jackson数据绑定依赖:

<dependency>
    <groupId>com.fasterxml.jackson.core</groupId>
    <artifactId>jackson-databind</artifactId>
    <version>2.12.4</version>
</dependency>

启用消息转换

Spring MVC提供了简化的配置方式,无需手动声明RequestMappingHandlerAdapter,仅需开启注解驱动:

<mvc:annotation-driven/>

该配置会自动检测classpath中的Jackson依赖并注册对应的HTTP消息转换器。

Controller实现示例

@RestController
@RequestMapping("/api")
public class UserController {
    
    @GetMapping("/users")
    public List<User> fetchUsers() {
        List<User> result = new ArrayList<>();
        for (int idx = 1; idx <= 3; idx++) {
            User item = new User();
            item.setId(idx);
            item.setName("张三");
            item.setAge(18);
            result.add(item);
        }
        return result;
    }
}

@ResponseBody注解深度解析

该注解作用于Controller方法,指示Spring将返回值直接写入HTTP响应体,跳过视图解析流程。其核心功能包括:

  • 自动序列化Java对象为JSON/XML格式
  • 替代传统HttpServletResponse手动输出流操作
  • 支持Ajax异步请求的数据交互场景

对比示例:传统方式 vs 注解方式

// 传统方式:手动处理响应流
@RequestMapping("/legacy")
public void legacyResponse(HttpServletResponse resp) throws IOException {
    Account acc = new Account();
    acc.setEmail("123@qq.com");
    acc.setId(1001);
    acc.setPassword("******");
    acc.setUsername("tom");
    
    resp.getWriter().write(JSON.toJSONString(acc));
}

// 现代方式:自动转换
@ResponseBody
@RequestMapping("/modern")
public Account modernResponse() {
    Account acc = new Account();
    acc.setEmail("123@qq.com");
    acc.setId(1001);
    acc.setPassword("******");
    acc.setUsername("tom");
    return acc;
}

实际应用场景

@PostMapping("/authenticate")
@ResponseBody
public Map<String, Object> authenticate(Credentials cred, String captcha) {
    Map<String, Object> feedback = new HashMap<>();
    
    if (cred == null) {
        feedback.put("status", "error");
        feedback.put("info", "请填写用户信息");
        return feedback;
    }
    if (captcha == null || captcha.isEmpty()) {
        feedback.put("status", "error");
        feedback.put("info", "请填写验证码");
        return feedback;
    }
    
    feedback.put("status", "success");
    feedback.put("info", "登录成功");
    return feedback;
}

Vue事件绑定的简洁写法

当事件处理逻辑仅为单行表达式时,可直接内联书写,无需额外定义方法:

<button @click="counter++">增加计数</button>
<input @input="query = $event.target.value">

集合数据的JSON序列化形态

使用@ResponseBody返回List集合时,Jackson会生成JSON数组结构,每个元素对应集合中的对象实例。

服务端实现

@Controller
public class FurnitureController {
    
    @Autowired
    private FurnService furnService;
    
    @GetMapping("/furnitures")
    @ResponseBody
    public ResponseWrapper listAll() {
        List<Furniture> items = furnService.queryAll();
        return ResponseWrapper.ok().attach("items", items);
    }
}

@Service
public class FurnServiceImpl implements FurnService {
    @Override
    public List<Furniture> queryAll() {
        // 传入null查询全部记录
        return furnMapper.selectByExample(null);
    }
}

输出JSON结构

{
    "code": 200,
    "message": "success",
    "data": {
        "items": [
            {
                "id": 1,
                "name": "北欧风书桌",
                "brand": "宜家",
                "price": 899.00,
                "sold": 256,
                "inventory": 45,
                "image": "assets/products/desk-01.jpg"
            },
            {
                "id": 2,
                "name": "人体工学椅",
                "brand": "赫曼米勒",
                "price": 3680.00,
                "sold": 89,
                "inventory": 12,
                "image": "assets/products/chair-02.jpg"
            }
        ]
    }
}
标签: Spring MVC

相关文章

Linux crontab 详解

1) crontab 是什么cron 是 Linux 的定时任务守护进程;crontab 是用来编辑/查看“按时间周期执行命令”的表(cron table)。常见两类:用户 crontab:每个用户一份(crontab -e 编辑)系统级 crontab / cron.d:可指定执行用户(/etc/crontab、/etc/cron.d/*)2) crontab 时间...

富文本里可以允许的 HTML 属性

一、所有标签默认允许的安全属性(极少)class        (可选)id           (通常建议禁用)title️ 注意:id 容易被滥用做锚点注入,很多系统直接禁用class 允许的话最好只允许固定前缀(如 editor-*)二、a 标签允许属性<a href="" t...

Mac 安装 Node.js 指南

方法一:通过官网安装包(最简单,适合初学者)如果你只是想快速安装并开始使用,这是最直接的方法。访问 Node.js 官网。页面会显示两个版本:LTS (Recommended For Most Users):长期支持版,最稳定。建议选这个。Current:最新特性版,包含最新功能但可能不够稳定。下载 .pkg 安装包并运行。按照安装向导点击“下一步”即可完成。方法二:使用 Homebrew 安装(...

Dom\HTML_NO_DEFAULT_NS 的副作用:自动加闭合标签

在使用Dom\HTMLDocument时,Dom\HTML_NO_DEFAULT_NS 将禁止在解析过程中设置元素的命名空间, 此设置是为了与DOMDocument向后兼容而存在的。当使用它时,已知的一个副作用就是:自动加闭合标签例如 </img> 为什么会这样?当你使用:Dom\HTML_NO_DEFAULT_NS文档会变成 无命名空间模式,此时内部更接近 XML...

Laravel 事件和监听器创建

在 Laravel 中,使用 Artisan 命令创建 Events(事件) 和 Listeners(监听器) 是非常高效的。你可以通过以下几种方式来实现:1. 手动创建单个 Event如果你只想创建一个事件类,可以使用 make:event 命令:Bashphp artisan make:event UserRegistered执行后,文件将生成在 app/Even...

自定义域名解析神器 dnsmasq

什么是 dnsmasq?dnsmasq 是一个轻量级、功能强大的网络服务工具,专为小型和中等规模网络设计。它是一个综合的网络基础设施解决方案[1]。dnsmasq 能做什么?功能说明应用场景DNS 转发与缓存将 DNS 查询转发到上游服务器(ISP、Google DNS 等),并在本地缓存结果加快 DNS 查询速度,减少外部 DNS 流量本地 DNS解析本地网络设备的主机名,无需编辑&n...

发表评论

访客

◎欢迎参与讨论,请在这里发表您的看法和观点。