@RequestParam 注解的使用——Spring系列知识学习笔记

Posted 来老铁干了这碗代码

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了@RequestParam 注解的使用——Spring系列知识学习笔记相关的知识,希望对你有一定的参考价值。

一. 前言

在SpringMVC后台进行获取数据,一般是两种。

  1. request.getParameter(“参数名”)
  2. 用@RequestParam注解获取

下面讲解用法。

二. 参数名一致


springmvc会自动根据参数名字来注入,所以要名字一致,不然不会注入

/**
 * 后台代码
 */
@RequestMapping("/")
public String Demo1(@RequestParam String lid){
 
    System.out.println("值为:"+lid);
    return null;
}

/**
 * 前台页面
 */
<input type="text" name="lid" />  <!-- 这时输出为10 -->
 

/**
 * 输出界面
 */
值为:10

三. 参数名字不一致


参数名字不一致的话,需要在@RequestParam后面指定参数名字,才能为后面的参数进行赋值。

/**
 * 后台代码
 */
@RequestMapping("/")
public String Demo1(@RequestParam(name="lid") String id){
 
    System.out.println("值为:"+id);
    return null;
}

/**
 * 前台页面
 */
<input type="text" name="lid" />  <!-- 这时输出为10 -->


/**
 * 输出界面
 */
值为:10

四. 设置默认值


/**
 * 后台代码
 */
@RequestMapping("/")
public String Demo1(@RequestParam(name="lid",defaultValue="ste") String id){
 
    System.out.println("值为:"+id);
    return null;
}


/**
 * 无前台页面
 */


/**
 * 输出界面
 */
值为:ste

五. 注意事项


如果要@RequestParam为一个int型的数据传值,假如前端并未输入,那么将会为int型的数据赋值为null。显然,这是不允许的,直接报错:

/**
 * 后台代码
 */
@RequestMapping("/")
public String Demo1(@RequestParam(name="lid") int id){
 
    System.out.println("值为:"+id);
    return null;
}

/**
 * 前台页面
 */
<input type="text" name="lid" />  <!-- 这时输出为10 -->
 
/**
 * 输出界面
 */
值为:10

可以通过required=false或者true来要求@RequestParam配置的前端参数是否一定要传。如:

// required=true,则参数必须要传
@RequestMapping("/")
public String Demo1(@RequestParam(name="lid",required=true) int id){
 
    System.out.println("值为:"+lid);
    return null;
}`

如果required为false,那么默认为参数赋值为null

以上是关于@RequestParam 注解的使用——Spring系列知识学习笔记的主要内容,如果未能解决你的问题,请参考以下文章

@RequestParam注解的使用

@RequestParam注解

@RequestParam注解详细使用

@RequestParam注解加与不加的区别

@RequestParam注解参数

SpringMVC的@RequestParam注解(eclipse)