兼容IE浏览器的PrintArea

  最近遇到,PrintArea在Chrome中有打印预览,在IE中并不会有打印预览,但是又必须对IE兼容,IE浏览器必须和对方提供的思路完全一致(IE中使用右键打印)。故更改了一下打印方式。

1 原有chrome打印。

(1) 引入Jquery框架后,由于打印的一种选项中是选中ifream,先写个ifream

  

 <iframe class="CenterBox" id="frame" style="overflow-x:hidden"></iframe>

(2)然后向ifream中填充内容,采用的是点击按钮的形式进行加载,

 

    function YuLan(recID) {
            $(".CenterBox").attr("src", "ChkView/YuLan?RecID=" + recID);
        }

(3)写个打印按钮

 

<button class="btn btn-primary" type="button" onclick="Print()">打印</button>

由此触发打印

(4)打印方法:

    function Print() {
            var iframe = document.getElementById('frame');
            //iframe.contentWindow.document.getElementById('printBox').style.overflow = 
              //"inherit";
            iframe.contentWindow.focus();
            iframe.contentWindow.print();
        }

-------------------------------------------------------------------------------------------------------------------------------

使用PrintArea在IE浏览器会直接进入打印选项,并不能进行预览,客户要求必须按照他自己做的程序实现:点击打印,转到打印预览,右键进行打印。故选择了新打开一个预览界面,来模拟打印预览。为了保证Chrome的体验,判断当前浏览器是Chrome还是IE。先来demo。

(1)

function isIE(){

  if (window.navigator.userAgent.indexOf("MSIE")>=1)

  return true;

   else

   return false;

}

 

 

e10及以上不支持ie浏览器的判断了,因为ie11已经不支持document.all了,下面是支持ie11的版本的,当然ie6-8也是支持的

function isIE() { //ie?

 if (!!window.ActiveXObject || "ActiveXObject" in window)

  return true;

  else

  return false;

 }

 

 

 

注:判断IE部分来自:http://www.jb51.net/article/76296.htm

那么接下来就可以写判断了。上代码:

 

     function Print() {
            if (!!window.ActiveXObject || "ActiveXObject" in window) {
               
                var iframe = document.getElementById('frame');
                var src = $(iframe).attr("src");
                var url = window.location.href;
                var usedUrl = url.substring(0, url.indexOf("CCheck"));
                var thisUrl = usedUrl + "CCheck/" + src + "";
                window.open(thisUrl);
            }
            else {
                var iframe = document.getElementById('frame');
                iframe.contentWindow.focus();
                iframe.contentWindow.print();
            }
        }

 

修改了原Print()方法,如果不是IE浏览器,使用原方法,如果是IE浏览器,获得ifream 并获取其src。

截取、拼接Url,使用windows.open(thisUrl)直接打开新页面。

注:需要打印的页面,可以直接拼接Url就可以打开,也就是使用get请求返回界面。

 

 

 

 

 

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 你可以通过以下步骤下载jquery.printarea.js: 1. 打开你常用的浏览器,如Google Chrome或Mozilla Firefox。 2. 在搜索栏中输入“jquery.printarea.js”并按下Enter键。 3. 在搜索结果中找到合适的下载源,如GitHub或其他开源仓库。 4. 点击下载链接,通常是一个绿色的“Download”按钮。 5. 如果有选择下载版本的选项,请选择最新的稳定版本。 6. 选择保存的位置,在“保存到”或“保存路径”字段中选择一个文件夹。 7. 单击“保存”按钮开始下载。 8. 等待下载完成,这可能需要一段时间,具体取决于你的网络速度。 9. 下载完成后,你将看到一个通知或进度条。 10. 在文件管理器中,导航至你选择保存的文件夹,找到下载的jquery.printarea.js文件。 11. 现在你可以将该文件用于你的项目或网站。 请注意,确保从可信的和安全的下载源下载jquery.printarea.js,这样可以避免潜在的安全风险。下载的文件应该被用于合法目的,如开发、学习或个人使用。 ### 回答2: jquery.printarea.js是一款基于jQuery开发的插件,用于在网页中实现打印页面的功能。它提供了简单易用的API,让我们可以轻松地在网页中指定打印区域,并进行自定义的打印操作。 要下载jquery.printarea.js,可以前往GitHub或者其他代码托管平台搜索该插件的源码。在相应的页面中,我们可以找到下载链接或者直接复制代码。将下载下来的js文件保存到本地的项目目录中,然后在网页中引入这个js文件即可开始使用。 在使用jquery.printarea.js之前,我们需要先引入jQuery库,确保在使用插件的时候,jQuery库已经被正确加载。然后,我们可以使用jQuery选择器来选中需要打印的区域,给该区域添加一个唯一的ID或者类名。接下来,我们可以使用jquery.printarea.js提供的方法,通过调用参数为选中区域的ID或者类名,来实现打印功能。 通过使用jquery.printarea.js插件,我们可以实现自定义的打印设置,例如选择打印区域、设置打印纸张大小、设置打印页眉页脚等等。这样,我们就可以在网页中实现更加灵活和个性化的打印功能,提高用户体验。 总之,jquery.printarea.js是一款方便实用的插件,可以帮助我们在网页中实现打印页面的功能。下载和使用该插件只需在相应的代码托管平台下载源码,并在网页中引入该js文件即可。通过使用该插件,我们可以实现自定义的打印设置,提高用户的打印体验。 ### 回答3: jquery.printarea.js是一个用于打印特定区域的jQuery插件。通过使用该插件,您可以在网页上选择需要打印的特定区域,然后将其转换为可供打印的格式。这对于需要在网页上打印特定内容的应用程序非常有用。 下载jquery.printarea.js的步骤如下: 1. 打开您的浏览器,并转到jquery.printarea.js的官方网站或可靠的第三方网站,例如Github。 2. 在网站的搜索栏中输入"jquery.printarea.js"并按下Enter键进行搜索。 3. 在搜索结果中找到并选择最相关的链接,以访问插件的下载页面。 4. 在下载页面上找到并点击"下载"或"Download"按钮,以开始下载jquery.printarea.js文件。 5. 等待下载完成,通常这个过程会很快。 6. 下载完成后,您将获得一个以.js为后缀的文件,即jquery.printarea.js。 7. 将该文件保存到您的项目文件夹中的适当位置,以便在您的应用程序中使用。 总结:下载jquery.printarea.js的过程包括查找并访问相关网站、下载插件文件并将其保存到适当位置。确保下载文件的来源可靠以及插件文件的完整性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值