用jquery插件实现pdf文件的在线预览,大概是怎么个思路

用jquery插件实现pdf文件的在线预览,大概是怎么个思路,第1张

其实也就是简单的在浏览器中实现一个打开pdf文件,并有类似预览功能的码世正边框。

其实在中国上经常见到类似的页面,在浏览器中打开pdf文档,可大部分都是由于版权的原因使用了一些很特殊的技术,自然很难模仿了。

即使有直接在浏览器打开的例子,也必须手动点击一下链接然后才能打开pdf文件。如何直接打开,而不用点击链接呢?

本以为自己对js很熟,也就使用js模拟点击,可就是不管用,没办法,只能在中国上继续寻找资料。最终想不到代码却很简单。

最主要的是使用到了一返携个jquery的插件jquery.media.js,使用这个插件就很容易实现了。

核心代码:

河套西部一次局地大暴雨成因分析使用jquery.media.js就可以迟悔直接把一个连接到pdf文件的链接打

jQuery File Upload是上传文件的一个插件,不一定是图片,所以里面没做预览的支持。但是可以直接用jquery简单实现出来,代码如下:

/*

先在js里扩展一个uploadPreview方法

使用方法: 

<div>

<img id="ImgPr" width="120" height="120" /></div>

<input type="file" id="up" />

把需要进行预览的IMG标签外 套一个DIV 然后给上传控件ID给敬李予uploadPreview事件

$("#up").uploadPreview({ Img: "ImgPr", Width: 120, Height: 120, ImgType: ["gif", "jpeg", "jpg", "bmp", "png"], Callback: function () { }})

*/

jQuery.fn.extend({

    uploadPreview: function (opts) {

        var _self = this,

            _this = $(this)

        opts = jQuery.extend({

            Img: "ImgPr",

            Width: 100,

            Height: 100,

            ImgType: ["gif", "jpeg", "jpg", "bmp", "png"],

            Callback: function () {}

        }, opts || {})

        _self.getObjectURL = function (file) {

            var url = null

            if (window.createObjectURL != undefined) {

                url = window.createObjectURL(file)

            } else if (window.URL != undefined) {

                url = window.URL.createObjectURL(file)

            } else if (window.webkitURL != undefined) {

                url = window.webkitURL.createObjectURL(file)

            }

            return url

        }

        _this.change(function () {

            if (this.value) {

                if (!RegExp("\.(" + opts.ImgType.join("|") + ")$", "i").test(this.value.toLowerCase())) {

                    alert("选择文件错误,图片类型必须是" + opts.ImgType.join(",") + "中的一种")

                    this.value = ""

                    return false

                }

                if ($.browser.msie) {

                    try {

                        $("#" + opts.Img).attr('src', _self.getObjectURL(this.files[0]))

                    } catch (e) {

                        var src = ""

                        简芹var obj = $("#" + opts.Img)

                        var div = obj.parent("div")[0]

                        _self.select()

                        if (top != self) {

                            window.parent.document.body.focus()

                        } else {

                            _self.blur()

                        }

                        src = document.selection.createRange().text

                        document.selection.empty()

                        obj.hide()

                        obj.parent("div").css({

                            'filter': 'progid:DXImageTransform.Microsoft.AlphaImageLoader(sizingMethod=scale)',

                            'width': opts.Width + 'px',

                            'height': opts.Height + 'px'

                        })

                        div.filters.item("DXImageTransform.Microsoft.AlphaImageLoader").src = src

                   拦稿毕 }

                } else {

                    $("#" + opts.Img).attr('src', _self.getObjectURL(this.files[0]))

                }

                opts.Callback()

            }

        })

    }

})

然后是HTML页面进行调用:

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "

<html xmlns="

<head>

<title>图片上传预览演示</title>

<script src="jquery.min.js" type="text/javascript"></script>

<script src="16/uploadPreview.js" type="text/javascript"></script>

<script>

$(function () {

$("#up").uploadPreview({ Img: "ImgPr", Width: 120, Height: 120 })

})

</script>

</head>

<body>

<div style="width:500pxmargin:0px auto"><h2>图片上传预览演示</h2>

<div><img id="ImgPr" width="120" height="120" /></div>

<input type="file" id="up" />

</div>

</body>

</html>

使用ajaxfileupload对文件进行上传,上传完成后显示在该页上,即可以预览,想要实现该效果,只需要在上传成功之后服务端返回该图片在服务端的路径地址给前端,在ajax的success回调函数中,动态的设置页面上img节点的src属性为该地址路径即可。具体示例代码可以参考:

Html

<div class="uploadPicture">  

  拆行好     <img id="imgHead" src="" width="106" height="122" alt="头像">   

       <input type="file" onchange="uploadHead()" id="basicInfoHead" style="display:none"  

        name="basicInfoHead" />  

      <input type="hidden" id="basicHeadUrl" >  

       <a href="#basicInfo" id="uploadBasicInfoHead" >上传头像</a>  

      </div>

Javascript

//上传头像,触发click方法  

    $('#uploadBasicInfoHead').on('click',function(){  

     $('#basicInfoHead'旅铅).click()  

    })  

  

function uploadHead(){  

  $.ajaxFileUpload({  

      url:"${pageContext.request.contextPath}/profile/uploadBasicHead",//需要链接到服务器地址   

      secureuri:false,  

      fileElementId:"basicInfoHead",//文件选择框的id属性  

      dataType: 'json',   //json  

      success: function (data) {  

         $("#imgHead").attr("src","${pageContext.request.contextPath}/profile/readImage?imagePath="+data.imagePath)  

        $('#basicHeadUrl').val(data.imagePath)  

      },error:function(XMLHttpRequest, textStatus, errorThrown){  

     alert('上传失败!')  

   }  

  })  

}

备注:后端需要对带衡应的返回上传成功的图片的url路径。


欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/tougao/12268848.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-05-22
下一篇2023-05-22

发表评论

登录后才能评论

评论列表(0条)

    保存