路由
当用户访问一个 URL 时,最终执行哪个模块下哪个控制器的哪个操作,这是由路由来解析后决定的。
ThinkJS 提供了一套灵活的路由机制,除了默认的解析外,还可以支持多种形式的自定义路由,让 URL 更加简单友好。
URL 解析为 pathname
当用户访问服务时,服务端首先拿到的是一个完整的 URL,如:访问本页面,得到的 URL 为 http://www.thinkjs.org/zh-cn/doc/2.0/route.html。
将 URL 进行解析得到的 pathname 为 /zh-cn/doc/2.0/route.html。
pathname 过滤
有时候为了搜索引擎优化或者一些其他的原因, URL 上会多加一些东西。比如:当前页面是一个动态页面,但 URL 最后加了 .html,这样对搜索引擎更加友好。但这些在后续的路由解析中是无用的,需要去除。
ThinkJS 里提供了下面的配置可以去除 pathname 的前缀和后缀内容:
export default {
pathname_prefix: '',
pathname_suffix: '.html',
}
上面配置可以在 src/common/config/config.js 中进行修改。
pathname 过滤时会自动去除左右的 /,该逻辑不受上面的配置影响。对 pathname 进行过滤后,拿到干净的 pathname 为 zh-cn/doc/2.0/route。
注:如果访问的 URL 是 http://www.thinkjs.org/,那么最后拿到干净的 pathname 则为空字符串。
路由识别
1.路由解析
路由识别默认根据: 模块/控制器/操作/参数1/参数1值/参数2/参数2值 来识别过滤后的 pathname,如:pathname 为 admin/group/detail,那么识别后的结果为:
module 为 admin
controller 为 group
action 为 detail,对应的方法名为 detailAction
如果项目里并没有 admin 这个模块或者这个模块被禁用了,那么识别后的结果为:
module 为默认模块 home
controller 为 admin
action 为 group,对应的方法名为 groupAction
参数为 {detail: ''}
如果有多级控制器,那么会进行多级控制器的识别,然后才是 action 的识别。
2.大小写转化
路由识别后,module、controller 和 Action 值都会自动转为小写。如果 Action 值里有 _,会作一些转化,如:假设识别后的 Controller 值为 index,Action 值为 user_add,那么对应的 Action 方法名为 userAddAction,但模版名还是 index_user_add.html。
路由默认值
当解析 pathname 没有对应的值时,此时便使用对应的默认值。其中 module 默认值为 home,controller 默认值为 index,action 默认值为 index。
这些值可以通过下面的配置进行修改,配置文件 src/common/config/config.js:
export default {
default_module: 'home',
default_controller: 'index',
default_action: 'index',
}