繁体   English   中英

MVC3 C#Razorview使用Java脚本打印PartialView

[英]MVC3 C# Razorview Printing a PartialView using Javascript

我正在尝试让按钮打印局部视图。

| 主视图| 局部视图|

| 用户| 简介|


在用户之上,我具有链接,用户可以单击以访问他的个人资料或他的报告等。我创建了一个链接,以使用Media Print CSS打印他们的个人资料,以使其在纸上看起来完美。

我遇到的问题是使它起作用。

function print_url () {
  location: url;
  print();
}
<li data-username="@Model.UserName"><a href="javascript:print_url('URL/Home/ContentView?username=@Model.UserName')">Print Profile</a></li>

这必须适用于所有浏览器。 Chrome只是说没有可用的视图,firefox没有响应,IE也没什么:(。

如果您有任何想法,那就太好了。

AJAX

getUserData: function (elem) {
  $elem = $(elem).closest("[data-username]");
  var username = $elem.data("username");
  var profile = $elem.data("profile");
  var directReport = $elem.data("direct-report");
  $.ajax({
    url: 'Home/ContentView?username=' + username,
    type: 'GET',
    data: username,
    data: profile,
    data: directReport,
    beforeSend: function () {
      $('#loader').css('display', 'block');
    },
    success: function (result) {
      $("#content").html(result).scrollTop(result);
      //$("#tabs").fadeIn('1500');
      //console.log(result + '\n\n DONE');
    },
    error: function (e, msg) {
      //console.log(e, msg);
    }
  })

弃儿

好的,您输入一个location: url ,然后(一旦我想它已经进入了url),就调用print()。 但是,该语句永远不会被击中,因为更改位置类似于return语句,即所有执行都在该点终止。

是否有可能适合您的替代方案,即执行jquery ajax调用,或者jquery不适用(我看不到标签)。 我们戈拉在这里快! :-)

此外, @Url.Action() ,您的URL定义非常脆弱,您至少应考虑使用@Url.Action()即:

<a href="javascript:print_url('@Url.Action("action", "controller, new {username=@Model.UserName}, null)'">

...相反,因为无论您的主机配置如何,这都将保证保真度。 我的坚定建议是使用Ajax调用您的partialview 根据您提供的信息,没有其他方法可以为您工作。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM