一、jsp程序中的EL表达式,用于从对应的域中获取需要的数据。
如:
<input type="hidden" name="id" value="${requestScope.book.id}">
二、html页面的${},属于模板引擎语法 ,常与thymeleaf结合起来使用。在html使用${},需要先在控制器@Controller类里面先用域对象往域中存好数据,下面例子使用的是model域对象。
1,@Controller:
@Controller public class EmployeeController { @Autowired private EmployeeDao employeeDao; @RequestMapping(value = "/employee",method = RequestMethod.GET) public String getAll(Model model){ Collection<Employee> employees = employeeDao.getAll(); model.addAttribute("employees",employees); return "employ_list"; }
}
2,html页面:
①配置好xmlns:th
②使用thymeleaf和${}获取域中的数据
<!DOCTYPE html> <html lang="en" xmlns:th="http://www.thymeleaf.org"> ←---此处需要配置一下xmlns:th <head> <meta charset="UTF-8"> <title>employ_list</title> </head> <body> <table border="1" cellspacing="0" cellpadding="0" style="text-align: center" id="dataTable"> <tr> <th colspan="5">employee_info</th> </tr> <tr> <th>id</th> <th>lastName</th> <th>email</th> <th>gender</th> <th>options(<a th:href="@{/toAdd}">add</a>)</th> </tr> <tr th:each="employee:${employees}"> ←----此处是${}的使用场景 <td th:text="${employee.id}"></td> <td th:text="${employee.lastName}"></td> <td th:text="${employee.email}"></td> <td th:text="${employee.gender}"></td> <td> <a th:href="@{'/employee/'+ ${employee.id}}">update</a> <a @click="deleteEmployee" th:href="@{'/employee/'+${employee.id}}">delete</a> <!-- <a class="deleteEmployee"--> <!-- th:href="@{'/employee/'+ ${employee.id}}">delete</a>--> </td> </tr> </table>
.....
三、在mybatis的配置文件【例:mybatis-config.xml】里引入连接数据库所需要的properties文件的信息
xml version="1.0" encoding="UTF-8" ?> <!DOCTYPE configuration PUBLIC "-//MyBatis.org//DTD Config 3.0//EN" "http://MyBatis.org/dtd/MyBatis-3-config.dtd"> <configuration> <!--引入properties文件,此时就可以${属性名}的方式访问属性值--> <properties resource="jdbc.properties"></properties> <settings> <!--将表中字段的下划线自动转换为驼峰--> <setting name="mapUnderscoreToCamelCase" value="true"/> <!--开启延迟加载--> <setting name="lazyLoadingEnabled" value="true"/> </settings> <typeAliases> <!-- typeAlias:设置某个具体的类型的别名 属性: type:需要设置别名的类型的全类名 alias:设置此类型的别名,且别名不区分大小写。若不设置此属性,该类型拥有默认的别名,即类名 --> <!--<typeAlias type="com.atguigu.mybatis.bean.User"></typeAlias>--> <!--<typeAlias type="com.atguigu.mybatis.bean.User" alias="user"> </typeAlias>--> <!--以包为单位,设置改包下所有的类型都拥有默认的别名,即类名且不区分大小写--> <package name="com.atguigu.mybatis.bean"/> </typeAliases> <!-- environments:设置多个连接数据库的环境【即时有多个环境,也只会使用其中一个environment】 属性: default:设置默认使用的环境的id --> <environments default="mysql_test"> <!-- environment:设置具体的连接数据库的环境信息 属性: id:设置环境的唯一标识,可通过environments标签中的default设置某一个环境的id,表示默认使用的环境 --> <environment id="mysql_test"> <!-- transactionManager:设置事务管理方式 属性: type:设置事务管理方式,type="JDBC|MANAGED" type="JDBC":设置当前环境的事务管理都必须手动处理 type="MANAGED":设置事务被管理,例如spring中的AOP --> <transactionManager type="JDBC"/> <!-- dataSource:设置数据源【家钟笔记:整合SSM后,myBatis就不需要整合数据源了】 属性: type:设置数据源的类型,type="POOLED|UNPOOLED|JNDI" type="POOLED":使用数据库连接池,即会将创建的连接进行缓存,下次使用可以从缓存中直接获取,不需要重新创建 type="UNPOOLED":不使用数据库连接池,即每次使用连接都需要重新创建 type="JNDI":调用上下文中的数据源 --> <dataSource type="POOLED"> <!--设置驱动类的全类名--> <property name="driver" value="${jdbc.driver}"/> <!--设置连接数据库的连接地址--> <property name="url" value="${jdbc.url}"/> <!--设置连接数据库的用户名--> <property name="username" value="${jdbc.username}"/> <!--设置连接数据库的密码--> <property name="password" value="${jdbc.password}"/> </dataSource> </environment> </environments> <!--引入映射文件--> <mappers> <!-- <mapper resource="UserMapper.xml"/> --> <!-- 以包为单位,将包下所有的映射文件引入核心配置文件 注意: 1. 此方式必须保证mapper接口和mapper映射文件必须在相同的包下 2. mapper接口要和mapper映射文件的名字一致 --> <package name="com.atguigu.mybatis.mapper"/> </mappers> </configuration>