前端之家收集整理的这篇文章主要介绍了
Spring-使用注解开发,
前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
使用注解开发
@H_
301_2@
@H_
301_2@
@H_
301_2@在Spring4之后,要使用注解开发,必须要保证AOP的包导入了(直接导入spring-mvc包含此jar包)
@H_
301_2@使用注解需要导入context约束,
增加注解的
支持!
1. bean
@H_
301_2@@Component
@H_
301_2@组件,放在类上,说明这个类被Spring管理了,就是bean!
package com.wang.pojo;
import org.springframework.stereotype.Component;
//等价于 <bean id="user" class="com.wang.pojo.User"/>
//@Component 组件,bean的名字默认为小写class
@Component
public class User {
public String name = "wang sky";
}
2. 属性如何注入
@H_
301_2@@value
@H_
301_2@放在
属性或者对应的Setter上
public class User {
//相当于 <bean id="user" class="com.wang.pojo.User">
// <property name="name" value="sky wang"/>
// </bean>
@Value("sky wang")
public String name;
}
3. 衍生的注解
@H_
301_2@@Component 有几个衍生的注解. 在Web开发中,会按照MVC三层架构分层
- dao层 @Repository
- service层 @Service
- controller层 @Controller
@H_
301_2@这四个注解的
功能都是一样的,都是代表将某个类
注册到Spring容器中,装配bean
@H_
301_2@@Autowired
自动装配,byType
@H_
301_2@配合@Qualified(value = "XXX") 可以实现byName的
自动装配
@H_
301_2@@Nullable
属性标记后,表示该
属性可以为null
@H_
301_2@@Resource
自动装配,byName,找不到Name会byType
5. 作用域
@H_
301_2@@Scope("singleton")
@H_
301_2@@Scope("prototype")等
@H_
301_2@与xml中配置的一致
6. 总结
@H_
301_2@xml与注解
- xml 更加万能,适用于任何场合! 维护简单方便
- 注解 不是直接的类用不了,维护相对复杂!
@H_
301_2@xml 与 注解的最佳实践
- xml 用来管理bean
- 注解只负责完成属性的注入
- 我们在使用的过程中,只需要注意一个问题: 必须让注解生效,就需要开启注解的支持
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:context="http://www.springframework.org/schema/context"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans.xsd
http://www.springframework.org/schema/context
https://www.springframework.org/schema/context/spring-context.xsd">
<!--指定要扫描的包,这个包下的注解就会生效-->
<context:component-scan base-package="com.wang"/>
<context:annotation-config/>
<!-- <bean id="user" class="com.wang.pojo.User">-->
<!-- <property name="name" value="sky wang"/>-->
<!-- </bean>-->
</beans>