mirror of
https://gitee.com/fastadminnet/framework.git
synced 2026-07-01 12:42:48 +08:00
改进自动路由标识生成 支持不同的路由规则 指向同一个路由标识,改进Url自动生成对路由标识的支持
This commit is contained in:
@@ -301,7 +301,7 @@ class Route
|
||||
}
|
||||
$vars = self::parseVar($rule);
|
||||
if (isset($name)) {
|
||||
self::$name[$name] = [$rule, $vars, self::$domain];
|
||||
self::$name[$name][] = [$rule, $vars, self::$domain];
|
||||
}
|
||||
if ($group) {
|
||||
if ('*' != $type) {
|
||||
|
||||
@@ -234,18 +234,19 @@ class Url
|
||||
// 匹配路由地址
|
||||
public static function getRuleUrl($rule, &$vars = [])
|
||||
{
|
||||
list($url, $pattern) = $rule;
|
||||
foreach ($pattern as $key => $val) {
|
||||
if (isset($vars[$key])) {
|
||||
$url = str_replace(['[:' . $key . ']', '<' . $key . '?>', ':' . $key . '', '<' . $key . '>'], $vars[$key], $url);
|
||||
unset($vars[$key]);
|
||||
} elseif (2 == $val) {
|
||||
$url = str_replace(['/[:' . $key . ']', '[:' . $key . ']', '<' . $key . '?>'], '', $url);
|
||||
} else {
|
||||
return false;
|
||||
foreach ($rule as $item) {
|
||||
list($url, $pattern) = $item;
|
||||
foreach ($pattern as $key => $val) {
|
||||
if (isset($vars[$key])) {
|
||||
$url = str_replace(['[:' . $key . ']', '<' . $key . '?>', ':' . $key . '', '<' . $key . '>'], $vars[$key], $url);
|
||||
unset($vars[$key]);
|
||||
return $url;
|
||||
} elseif (2 == $val) {
|
||||
return str_replace(['/[:' . $key . ']', '[:' . $key . ']', '<' . $key . '?>'], '', $url);
|
||||
}
|
||||
}
|
||||
}
|
||||
return $url;
|
||||
return false;
|
||||
}
|
||||
|
||||
// 指定当前生成URL地址的root
|
||||
|
||||
@@ -56,7 +56,7 @@ class urlTest extends \PHPUnit_Framework_TestCase
|
||||
|
||||
public function testBuildMethod()
|
||||
{
|
||||
Route::get('blog/:id', ['\app\index\controller\blog', 'read']);
|
||||
Route::get('blog/:id', '\app\index\controller\blog@read');
|
||||
$this->assertEquals('/blog/10.html', Url::build('\app\index\controller\blog\read', 'id=10', 'html'));
|
||||
}
|
||||
|
||||
|
||||
Reference in New Issue
Block a user