8、使用注解开发
在spring4之后,要使用注解开发,必须要保证aop的包导入了,pom.xml中添加webmvc依赖即可。
使用注解需要导入context约束,增加注解的支持!
<?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
https://www.springframework.org/schema/beans/spring-beans.xsd
http://www.springframework.org/schema/context
https://www.springframework.org/schema/context/spring-context.xsd">
<context:annotation-config/>
</beans>
-
bean
<!-- 指定要扫描的包,这个包下的注解就会生效 --> <context:component-scan base-package="com.kuang.pojo"/>
-
属性如何注入
直接在属性字段上加上@Value(“xxx”)
//等价于 <bean id="user" class="com.kuang.pojo.User"/> //现在使用注解开发,只需要一个注解就都解决了 // @Component -- 组件 @Component public class User { //相当于 <property name="name" value="文涛"/> @Value("文涛") public String name; }
或在set方法上加上@Value(“xxx”):
@Component public class User { public String name; //相当于 <property name="name" value="文涛"/> @Value("文涛") public void setName(String name) { this.name = name; } }
-
衍生的注解
@Component 有几个衍生注解,我们在web开发中,会按照MVC三层架构分层!
- dao 【@Repository】-- 对应持久层
- service 【@Service】-- 对应服务层
- controller 【@Controller】-- 对应控制层
这四个注解功能都是一样的,都是代表将某个类注册到Spring容器中,装配Bean
- 自动装配置
@Autowired
@Resource
-
作用域
@Component @Scope("singleton") //单例模式,即每次bean容器生产的对象都是同一对象 "prototype"原型模式,即每次bean容器生产的对象为不同对象 public class User { public String name; //相当于 <property name="name" value="文涛"/> @Value("文涛") public void setName(String name) { this.name = name; } }
-
小结
xml与注解:
-
xml 更加万能, 适用于任何场合!维护简单方便
-
注解 不是自己的类使用不了,维护相对复杂!
xml与注解最佳实践:
- xml用来管理bean;
- 注解只负责完成属性的注入;
- 我们在使用的过程中,只需要注意一个问题:要让注解生效,就需要开启注解的支持!
-
<!-- 指定要扫描的包,这个包下的注解就会生效 -->
<context:component-scan base-package="com.kuang"/>
<context:annotation-config/>