6. 基本语言元素
有四个基本的流元件:
6.1. 元素flow
每个流都以以下根元素开头:
<?xml version="1.0" encoding="UTF-8"?>
<flow xmlns="http://www.springframework.org/schema/webflow"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://www.springframework.org/schema/webflow
https://www.springframework.org/schema/webflow/spring-webflow.xsd">
</flow>
流的所有状态都在此元素中定义。 定义的第一个状态将成为流的起点。
6.2. 元素view-state
该元素定义呈现视图的流的一个步骤:view-state
<view-state id="enterBookingDetails" />
按照惯例,视图状态会将其 ID 映射到流所在目录中的视图模板。
例如,如果流本身位于目录中,则可能会呈现上述状态。/WEB-INF/hotels/booking/enterBookingDetails.xhtml
/WEB-INF/hotels/booking
6.3. 元素transition
该元素处理状态中发生的事件:transition
<view-state id="enterBookingDetails">
<transition on="submit" to="reviewBooking" />
</view-state>
这些过渡驱动视图导航。
6.5. 检查点:基本语言元素
使用三个元素 、 、 和 ,您可以快速表达您的视图导航逻辑。
团队通常在添加流行为之前执行此操作,以便他们可以首先专注于与最终用户一起开发应用程序的用户界面。
以下示例流使用以下元素实现其视图导航逻辑:view-state
transition
end-state
<flow xmlns="http://www.springframework.org/schema/webflow"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://www.springframework.org/schema/webflow
https://www.springframework.org/schema/webflow/spring-webflow.xsd">
<view-state id="enterBookingDetails">
<transition on="submit" to="reviewBooking" />
</view-state>
<view-state id="reviewBooking">
<transition on="confirm" to="bookingConfirmed" />
<transition on="revise" to="enterBookingDetails" />
<transition on="cancel" to="bookingCancelled" />
</view-state>
<end-state id="bookingConfirmed" />
<end-state id="bookingCancelled" />
</flow>