将 javascript 变量作为参数传递给 @url.Action()
Pass a javascript variable as parameter to @url.Action()
是否可以将javascript变量作为参数传递给@url.Action(),因为据我所知可能存在服务器端和客户端问题,我的要求是我有根据过滤器下载文件,ajax调用不支持下载文件。所以我对 @url.Action() 进行了 harcode 工作但无法实现它,任何人都可以建议我如何将参数传递给 @url.Action() 或任何其他方法。
这是我的代码
<a href="@Url.Action("Export", new { SelectedAccountType="1", FromDate = "2014-02-02", ToDate = "2014-02-02", SelectedAccount = "", SelectedUser = "", SelectedTeam = "" })" class="btn-primary" id="exportbutton2"> Export as CSV</a>
这是我要分配给@Url.Action
的参数
<script type="text/javascript">
var accountType = $('#SelectedAccountType').val();
var fromDate = $('#FromDate').val();
var toDate = $('#ToDate').val();
var accountId = $('#SelectedAccount').val();
var userId = $('#SelectedUser').val();
var teamId = $('#SelectedTeam').val();
</script>
您需要使用 javascript/jquery 构建您 url。在视图中将 link 更改为
<a id="export" href=#">Export as CSV</a>
然后在脚本中
var baseurl = '@Url.Action("Export")';
$('#export').click(function() {
var url = baseurl + '?SelectedAccountType=' + $('#SelectedAccountType').val() + '&FromDate=' + $('#FromDate').val() + '&ToDate=' + $('#ToDate').val() + ...etc
location.href=url;
});
但是,如果您的表单标有 FormMethod.Get
,那么您只需使用普通的提交按钮即可,不需要 jquery
@using (Html.BeginForm("Export", "yourControllerName", FormMethod.Get))
{
@Html.TextBoxForm(m => m.SelectedAccountType)
....
<input type="submit" value="Export" />
}
是否可以将javascript变量作为参数传递给@url.Action(),因为据我所知可能存在服务器端和客户端问题,我的要求是我有根据过滤器下载文件,ajax调用不支持下载文件。所以我对 @url.Action() 进行了 harcode 工作但无法实现它,任何人都可以建议我如何将参数传递给 @url.Action() 或任何其他方法。
这是我的代码
<a href="@Url.Action("Export", new { SelectedAccountType="1", FromDate = "2014-02-02", ToDate = "2014-02-02", SelectedAccount = "", SelectedUser = "", SelectedTeam = "" })" class="btn-primary" id="exportbutton2"> Export as CSV</a>
这是我要分配给@Url.Action
的参数<script type="text/javascript">
var accountType = $('#SelectedAccountType').val();
var fromDate = $('#FromDate').val();
var toDate = $('#ToDate').val();
var accountId = $('#SelectedAccount').val();
var userId = $('#SelectedUser').val();
var teamId = $('#SelectedTeam').val();
</script>
您需要使用 javascript/jquery 构建您 url。在视图中将 link 更改为
<a id="export" href=#">Export as CSV</a>
然后在脚本中
var baseurl = '@Url.Action("Export")';
$('#export').click(function() {
var url = baseurl + '?SelectedAccountType=' + $('#SelectedAccountType').val() + '&FromDate=' + $('#FromDate').val() + '&ToDate=' + $('#ToDate').val() + ...etc
location.href=url;
});
但是,如果您的表单标有 FormMethod.Get
,那么您只需使用普通的提交按钮即可,不需要 jquery
@using (Html.BeginForm("Export", "yourControllerName", FormMethod.Get))
{
@Html.TextBoxForm(m => m.SelectedAccountType)
....
<input type="submit" value="Export" />
}