beego中带参数的UrlFor和urlfor的用法讲解

码途逸风
• 阅读 8500

我们知道,代码里面可以使用UrlFor或者模板里面使用urlfor来根据自定义Controller和方法来生成url。这里模板中使用的urlfor其实是UrlFor注册的模板方法,二者功能完全相同,一个用于代码中,另外一个用于模板中。

步骤如下:

  1. 自定义Controller,并且实现对应的方法Method
  2. 使用beego.Router注册路由,将自定义Controller实例和方法Method联系在一起
  3. 使用UrlFor函数在代码中或者urlfor在模板中生成url

上面的是我们经常会使用的方法,这里再分享一个带参数的UrlFor或者urlfor的用法。

package main

import (
    "fmt"
    "github.com/astaxie/beego"
)

type UserController struct {
    beego.Controller
}

func (this UserController) List() {

}

func main() {
    userController := UserController{}

    //注册路由
    beego.Router("/user/list/:name/:age", &userController, "*:List")
    beego.Router("/user/list", &userController, "*:List")

    //创建url
    //{{urlfor "UserController.List" ":name" "astaxie" ":age" "25"}}
    url := userController.UrlFor("UserController.List", ":name", "astaxie", ":age", "25")
    //输出 /user/list/astaxie/25
    fmt.Println(url)

    //{{urlfor "UserController.List" "name" "astaxie" "age" "25"}}
    url = userController.UrlFor("UserController.List", "name", "astaxie", "age", "25")
    //输出 /user/list?name=astaxie&age=25
    fmt.Println(url) 
}

我们上面分别使用了路由参数的方式和表单参数的方式来分别创建了两个url。对应的注释中是它们在模板中的使用方法。

/*
/user/list/astaxie/25
*/
{{urlfor "UserController.List" ":name" "astaxie" ":age" "25"}}
/*
/user/list?name=astaxie&age=25
*/
{{urlfor "UserController.List" "name" "astaxie" "age" "25"}}

需要注意的是,在模板中给方法提供的参数中间是用空格隔开的,另外注意路由参数和表单参数两种方式下,路由的注册方式和参数名称的提供方式。带冒号(:)的参数名是路由参数。另外参数的提供方式是依次以key-value方式提供的。

点赞
收藏
评论区
推荐文章
Jacquelyn38 Jacquelyn38
4年前
一篇文章带你使用Typescript封装一个Vue组件
搭建项目以及初始化配置vue create tsvuebtn这里使用了vueCLI3自定义选择的服务,我选择了ts、stylus等工具。然后创建完项目之后,进入项目。使用快捷命令code.进入Vscode编辑器(如果没有code.,需要将编辑器的「bin文件目录地址」放到环境变量的path中)。然后,我进入编辑器之后,进入设置工作区,随便设置一个
Wesley13 Wesley13
3年前
java通过sina端口提取股票历史数据并存入MySQL
 1.提取股票代码代码见:http://www.oschina.net/code/snippet\_2688840\_55337(http://www.oschina.net/code/snippet_2688840_55337) 2抓取sina股票的json页面数据;代码见:http://www.oschina.net/code/snip
威尔we 威尔we
4年前
使用 VS Code 来开发和调试 Python 程序
(简称VSCode)是微软出品的一款支持多种语言的免费IDE(集成开发环境)。VSCode轻量而强大,支持Windows、macOS和Linux。内置支持JavaScript、TypeScript和Node.js,并且拥有一个丰富的插件生态系统来支持其它语言(C/C、C、Java、Python、PHP、Go等)和运行时(.Net和
虾米大王 虾米大王
3年前
java代码020
code020.jsp解决中文乱码name参数的值为:sex参数的值为:
虾米大王 虾米大王
3年前
java代码074
code074.jspJDBC的使用,数据库连接
Wesley13 Wesley13
3年前
oracle的start with connect by prior如何使用
oracle的startwithconnectbyprior是根据条件递归查询"树",分为四种使用情况: 第一种:startwith子节点ID'...'connectbyprior子节点ID父节点IDselectfrommdm_organizationostartwitho.org_code'
Stella981 Stella981
3年前
SASS 使用(vs code)
二、在vscode中编译sass1、在拓展商店里搜索“easysass”,并安装,安装成功后点重新加载。!(https://oscimg.oschina.net/oscnet/cd1564b022465a6d848f658f854ed75a6c9.png)2、接下来进行配置:在vscode菜单栏依次点击“文件首选项设置
Wesley13 Wesley13
3年前
mysql _01
\where中不可以使用别名,因为where先于select执行以下是错误的SQL:select    code,   continentcont,   name,   populationpop from    country where    cont'asia'
Wesley13 Wesley13
3年前
APP 验证码 采用MEMCAHED验证的坑
都知道APP不是用浏览器来的,所以验证码生成sessioncookie是行不通了。一开始APP进入验证码界面,先让他请求一次服务器,生成key:code返回去。再把拿到的KEY带到服务器上面去生成图片。同时生成一个key:code再把key返回到客户端,当客户端验证图片的时候再把key再到服务器上去获取key里的code进行对比。一旦对比成功放行,对比
Stella981 Stella981
3年前
PowerDesigner列名、注释内容互换
在用PowerDesigner时,常常在NAME或Comment中写中文在Code中写英文,Name只会显示给我们看,Code会使用在代码中,但Comment中的文字会保存到数据库TABLE的Description中,有时候我们写好了Name再写一次Comment很麻烦,以下两段代码就可以解决这个问题。在PowerDesigner中PowerDesig
五、飞鹅官网API接口文档
接口列表1.获取网站信息请求方法:GET请求URL:/api/site/getSiteInfo请求参数无返回结果json"code":1,"data":"id":1,//id"title":"SampleSiteName",//网站名称"intro":"T
码途逸风
码途逸风
Lv1
墙里秋千墙外道。墙外行人,墙里佳人笑。笑渐不闻声渐悄,多情却被无情恼。
文章
5
粉丝
0
获赞
0