gpt4 book ai didi

java - 如何在Spring Boot MVC中更改View上的数据?

转载 作者:太空宇宙 更新时间:2023-11-04 09:15:13 24 4
gpt4 key购买 nike

如何更改 View 上的数据?例如,我有一个呈现输入的页面,我在其中写了单词,提交后(通过按钮或链接)我只是在同一页面上获得该单词的翻译。在我的代码中,我有服务方法 translate(),它在数据库中监视单词并获取 translatedWord。我如何呈现翻译后的单词?

 @GetMapping("/translate")
public String showTranslateForm() {
return "word-translate";
}

@PostMapping("/translate")
public String translateWord(@ModelAttribute("word") String wordToTranslate, Model model) {
String translatedWord = wordService.translate(wordToTranslate);

model.addAttribute("toTranslate", wordToTranslate);
model.addAttribute("translated", translatedWord);
return "redirect:/translate";
}

我需要 @ModelAttribute("word") 吗?因为我使用 model.addAttribute 东西?我不明白参数中的属性和方法主体中的属性之间有什么区别

最佳答案

您的后端可能看起来像这样(解释如下):

    @GetMapping("/translate")
public String showTranslateForm(Model model) {
if (model.getAttribute("toTranslate") != null) {
model.addAttribute("wordToTranslate");
}
if (model.getAttribute("translated") != null) {
model.addAttribute("translated");
}
return "word-translate";
}

@PostMapping("/translate")
public String translateWord(@RequestParam("word") String wordToTranslate,
RedirectAttributes attrs) {
String translatedWord = wordToTranslate.translate(wordToTranslate);

attrs.addFlashAttribute("toTranslate", wordToTranslate);
attrs.addFlashAttribute("translated", translatedWord);
return "redirect:/translate";
}

在你的前端(使用 Freemarker)你可以这样做:

<!DOCTYPE html>
<html>
<head>
</head>
<body>
<form action="/translate" method="post">
<input name="word" type="text" />
<input type="submit" value="submit">
</form>
<p>
<#if translated??>
${translated}
</#if>
<#if toTranslate??>
${toTranslate}
</#if>
</p>
</body>
</html>

您将通过在前端的输入中输入一些内容并点击提交按钮来发送一个值(您在 Controller 方法中期望的 word)。

提交会触发@PostMapping("/translate")下的方法。该方法将从输入字段获取值(因为输入属性 name=word ,它将绑定(bind)到此函数中的 wordToTranslate 参数,因为它前面有 @RequestParam("word") 注释)。我们还注入(inject)RedirectAttributes到这个函数中,这样我们就可以添加flash属性,这会将属性传递给showTranslateForm方法。

当属性传递到 showTranslateForm 时,model现在将包含 toTranslatetranslated键(我们在 translateWord 方法中添加为 flash 属性),现在可以在 Freemarker 模板中使用它们。顺便说一句,<#if translated??><#if toTranslate??> if 语句只是检查这些属性是否存在(因为当我们第一次进入此页面时它们最初不存在,但在重定向后它们会存在)。

我希望这些信息可以帮助您走上正轨!

关于java - 如何在Spring Boot MVC中更改View上的数据?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59112182/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com