利用docx-preview在线阅览word

html 复制代码
<!doctype html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport"
          content="width=device-width, user-scalable=no, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title></title>
    <style>
        body {
            margin: 0;
            padding: 0;
        }

        article > .docx_toc.docx-num-35-undefined {
            margin-bottom: 1em;
        }

        .docx_toc1 a, .docx_toc2 a {
            display: inline-block;
            width: 100%;
            overflow: hidden;
            color: #333;
            position: relative;
        }

        .docx_toc1 a > span, .docx_toc2 a > span {
            color: #333;
            text-decoration: none;
        }

        .docx_toc1 a > span:last-child, .docx_toc2 a > span:last-child {
            float: right;
            color: #333;
            background-color: #fff;
            text-indent: 1rem;
            z-index: 10;
            position: relative;
        }

        .docx_toc1 a > span:nth-last-child(2), .docx_toc2 a > span:nth-last-child(2) {
            position: absolute;
            display: inline-block;
            top: 50%;
            width: 95%;
            height: 0 !important;
            min-height: 1px;
            vertical-align: middle;
            border-bottom-style: dotted;
        }

        .docx_toc1 span.docx_afa {
            text-decoration: none;
        }

        .docx_toc1 a:hover span.docx_afa {
            text-decoration: underline;
            color: #000;
        }

        .docx_toc1 a:hover span.docx_afa:first-child {
            text-decoration: underline;
            color: #000;
        }

        .docx_toc1 a:hover span:last-child {
            text-decoration: underline;
            color: #000;
        }


        .docx_toc1 a:hover span > span {
            text-decoration: none !important;
        }

        .docx_toc2 a:hover span:last-child {
            text-decoration: underline;
            color: #000;
        }

        .docx_toc2 a:hover span.docx_afa {
            text-decoration: underline;
            color: #000;
        }

        .docx_toc2 a:hover span.docx_afa:first-child {
            text-decoration: underline;
            color: #000;
        }

        .docx_toc2 a:hover span > span {
            text-decoration: none !important;
        }
        article img{
            cursor: pointer;
            transition: .2s ease-in-out;
        }

        article img:hover {
            transform: scale(1.1);
            box-shadow: rgba(0, 0, 0, 0.1) 0 0 27px 10px;
            z-index: 10;
        }
    </style>
</head>

<!--lib uses jszip-->
<script src="https://unpkg.com/jszip/dist/jszip.min.js"></script>
<!-- docx-preview 可以npm install 下载,也可以使用官网cdn地址,自行百度-->
<script src="./js/docx-preview.min.js"></script>
<!-- <script src="https://volodymyrbaydalka.github.io/docxjs//dist/docx-preview.js"></script> -->

<body>
<div id="wordViewer"></div>
<script type="module">
    import {utils} from "./js/utils.js";

    let url = utils.getQueryVariable("url");
    url = url ? url : 'index.docx'
    wordView(url);
    console.log(document.getElementsByTagName("title"));
    document.getElementsByTagName("title")[0].text = url;

    function wordView(url) {
        let vm = this;
        let xhr = new XMLHttpRequest();
        xhr.open("get", url, true);
        xhr.responseType = "arraybuffer";
        xhr.onload = function () {
            if (xhr.status === 200) {
                docx.renderAsync(xhr.response, document.getElementById("wordViewer"))
                    .then(x => {console.log("docx: finished");mybind();});
            }
        };
        xhr.send();
    }

    function mybind(){
        var element = document.querySelectorAll("article img");
        console.log(element)
        for (let elementElement of element) {
            console.log(elementElement)
            elementElement.onclick = function (e) {
                // 忽略
            }
        }
    }
</script>

</body>
</html>

utils.js

js 复制代码
const utils = {
    getQueryVariable(variable) {
        let query = window.location.search.substring(1);
        let vars = query.split("&");
        for (var i = 0; i < vars.length; i++) {
            var pair = vars[i].split("=");
            if (pair[0] === variable) {
                return decodeURI(pair[1]);
            }
        }
        return false;
    },

    timerObj: {},

    /**
     * 防抖,点击再多次,最后一次生效
     *
     * @param id 操作id
     * @param call 操作函数
     * @param timeout 防抖间隔
     */
    antiShake(id, call, timeout) {
        let sortInputTimer = utils.timerObj[id];
        if (sortInputTimer) {
            // 杀掉上一个定时器
            clearTimeout(sortInputTimer);
        }
        // 开启下一个定时器
        utils.timerObj[id] = setTimeout(function () {
            clearTimeout(sortInputTimer);

            call ? call() : null;

            utils.timerObj[id] = 0;
        }, timeout ? timeout : 800);
    },

    /**
     * 限流,每次点击,只有第一次生效,到定时结束前,都不生效
     *
     * @param id 操作id
     * @param call 操作函数
     * @param timeout 限流间隔
     */
    currentLimit(id, call, timeout) {
        let sortInputTimer = utils.timerObj[id];
        // 如果有定时器,则不执行
        if (sortInputTimer) {
            return false;
        }
        call ? call() : null;
        // 开启一个定时器
        utils.timerObj[id] = setTimeout(function () {
            // 清空定时器
            clearTimeout(sortInputTimer);
            utils.timerObj[id] = 0;
        }, timeout ? timeout : 800);
    }
}

export {utils}
相关推荐
开心工作室_kaic33 分钟前
ssm068海鲜自助餐厅系统+vue(论文+源码)_kaic
前端·javascript·vue.js
有梦想的刺儿1 小时前
webWorker基本用法
前端·javascript·vue.js
cy玩具1 小时前
点击评论详情,跳到评论页面,携带对象参数写法:
前端
清灵xmf2 小时前
TypeScript 类型进阶指南
javascript·typescript·泛型·t·infer
小白学大数据2 小时前
JavaScript重定向对网络爬虫的影响及处理
开发语言·javascript·数据库·爬虫
qq_390161772 小时前
防抖函数--应用场景及示例
前端·javascript
334554322 小时前
element动态表头合并表格
开发语言·javascript·ecmascript
John.liu_Test2 小时前
js下载excel示例demo
前端·javascript·excel
Yaml43 小时前
智能化健身房管理:Spring Boot与Vue的创新解决方案
前端·spring boot·后端·mysql·vue·健身房管理
PleaSure乐事3 小时前
【React.js】AntDesignPro左侧菜单栏栏目名称不显示的解决方案
前端·javascript·react.js·前端框架·webstorm·antdesignpro