news 2026/4/23 14:37:27

Vue文档编辑器(Word默认功能)示例

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Vue文档编辑器(Word默认功能)示例

Spire.WordJS 基于 HTML5 标准,支持跨平台开发和集成,支持所有主流浏览器,无需安装任何插件或第三方组件,以原生的方式嵌入各类应用,可以与各类前端技术框架Vue、React、Angular 等相结合。 Spire.WordJS以纯前端、跨平台的能力,让您的应用系统轻松获得与Word,WPS文档一致的交互体验。

此示例为您完整演示Vue框架中如何使用Spire.WordJS文档编辑器创建、编辑并打印 Word 格式(DOCX)的文档:

<template> <div class="form"> <div id="iframeEditor"> </div> </div> </template> <script setup> import { ref, onMounted, onUnmounted } from 'vue'; import { storeToRefs } from 'pinia'; import { useFileStore } from '../stores/file.js' import { useRouter } from 'vue-router'; const fileStore = useFileStore() // Pinia 中当存储的数据 const { file, fileUint8Data } = storeToRefs(fileStore) const router = useRouter() const config = ref({}); const isOpened = ref(false); const editorInstance = ref(null); const apiInstance = ref(null); const originUrl = window.location.origin onMounted(() => { // 没有文件时直接跳回上传页 if (!file.value) { router.replace('/'); return; } // 使用script的方式载入 loadScript(); window.addEventListener('resize', OnWindowReSize); }) onUnmounted(() => { window.removeEventListener('resize', OnWindowReSize); }) // 初始化编辑器所需的配置对象 function initConfig() { if (!file.value) { throw new Error('未找到文件,请重新上传'); } if (!fileUint8Data.value) { throw new Error('未找到文件数据,请重新上传'); } config.value = { "fileAttrs": { "fileInfo": { "name": file.value.name, "ext": getFileExtension(), "primary": String(new Date().getTime()), "creator": "Jonn", "createTime": "2022-04-18 11:30:43" }, "sourceUrl": originUrl + "/files/__ffff_192.168.2.134/" + file.value.name, "createUrl": originUrl + "/open", "mergeFolderUrl": "", "fileChoiceUrl": "", "templates": {} }, "user": { "id": "uid-1", "name": "Jonn", "canSave": true, }, "editorAttrs": { "editorMode": "edit", //edit / view "editorWidth": "100%", "editorHeight": "100%", "editorType": "document", "platform": "desktop", //desktop / mobile / embedded "viewLanguage": "zh", //en / zh "isReadOnly": false, "canChat": true, "canComment": true, "canReview": true, "canDownload": true, "canEdit": true, "canForcesave": true, "embedded": { "saveUrl": "", "embedUrl": "", "shareUrl": "", "toolbarDocked": "top" }, "useWebAssemblyDoc": true, "useWebAssemblyExcel": true, "useWebAssemblyPpt": true, "spireDocJsLicense": "", "spireXlsJsLicense": "", "spirePresentationJsLicense": "", "spirePdfJsLicense": "", "serverless": { "useServerless": true, "baseUrl": originUrl, "fileData": fileUint8Data.value, }, "events": { "onSave": onFileSave }, "plugins": { "pluginsData": [] } } }; } // 创建并渲染 SpireCloudEditor 实例 function initEditor() { let iframeId = 'iframeEditor'; initConfig(); isOpened.value = true; editorInstance.value = new SpireCloudEditor.OpenApi(iframeId, config.value); // 创建编辑器实例 window.Api = apiInstance.value = editorInstance.value.GetOpenApi(); // 暴露 OpenApi 便于调试/保存 OnWindowReSize(); } // 获取上传文件的扩展名,用于配置 fileInfo.ext function getFileExtension() { const filename = file.value.name.split(/[\\/]/).pop(); // 获取最后一个点后的内容 return filename.substring(filename.lastIndexOf('.') + 1).toLowerCase() || ''; } // 调整编辑器容器尺寸,使其随窗口大小自适应 function OnWindowReSize() { let wrapEl = document.getElementsByClassName("form"); if (wrapEl.length) { wrapEl[0].style.height = screen.availHeight + "px"; window.scrollTo(0, -1); wrapEl[0].style.height = window.innerHeight + "px"; } } // 动态加载 SpireCloudEditor 脚本,避免重复注入 function loadScript() { if (window.SpireCloudEditor) { initEditor() return } const script = document.createElement('script'); script.setAttribute('src', '/spire.cloud/web/editors/spireapi/SpireCloudEditor.js'); script.onload = () => initEditor() document.head.appendChild(script); } // Spire 编辑器的保存回调,可接入自定义保存逻辑 function onFileSave(data) { console.log('save data', data) } </script> <style> .form, iframe, body { min-height: 100vh !important; min-width: 100vh !important; } </style>

Spire.WordJS文档编辑器界面选项清晰易懂,遵循Microsoft Word 和WPS通用规则,您可以快速在线完成 Word 文档的创建, 编辑, 打印及保存等。Spire.WordJS的每个独立功能均设为独立模块,可协助您搭建满足自身需求的轻量 Word 编辑工具。

Spire.WordJS文档编辑器核心功能:

  • 创建与编辑:打开和保存文档。
  • 支持的文档格式:.doc, .docx, .wps, .wpt, .docm, .dotm 等
  • 支持元素:文本、图片、超链接、表格、书签、页码、目录、页眉页脚等。
  • 格式设置:文本层级、段落层级、项目符号与编号、表格层级、页面设置及样式。
  • 编辑操作:撤销、重做、剪切、复制、粘贴。
  • 文档内文本查找替换。

如需要更多详细资料,请留言

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/23 9:45:53

AI研究不求人:DeerFlow快速入门与实战演示

AI研究不求人&#xff1a;DeerFlow快速入门与实战演示 你是否曾为写一篇行业分析报告熬到凌晨三点&#xff1f;是否在查资料时反复切换十几个网页&#xff0c;却仍找不到权威结论&#xff1f;是否想快速了解一个陌生技术领域&#xff0c;却不知从何下手&#xff1f;别再手动检…

作者头像 李华
网站建设 2026/4/23 9:46:42

用阿里Z-Image-Turbo生成带文字图片,清晰不模糊

用阿里Z-Image-Turbo生成带文字图片&#xff0c;清晰不模糊 你有没有试过用AI画图工具生成带中文文字的海报&#xff0c;结果文字糊成一片、笔画粘连、甚至完全识别不出字形&#xff1f;或者英文单词拼错、字母变形、排版歪斜&#xff1f;这不是你的提示词问题&#xff0c;而是…

作者头像 李华
网站建设 2026/4/23 9:47:52

Phi-3-mini-4k-instruct快速上手:无需配置的AI写作助手

Phi-3-mini-4k-instruct快速上手&#xff1a;无需配置的AI写作助手 你是不是也遇到过这些情况&#xff1a;想用AI写一段产品文案&#xff0c;却卡在环境安装上&#xff1b;下载了模型文件&#xff0c;发现还要配CUDA、调参数、改代码&#xff1b;打开一个网页工具&#xff0c;…

作者头像 李华
网站建设 2026/4/23 9:46:46

开发效率翻倍:coze-loop代码优化器真实体验,简单到爆

开发效率翻倍&#xff1a;coze-loop代码优化器真实体验&#xff0c;简单到爆 你有没有过这样的时刻&#xff1a;盯着一段自己写的代码&#xff0c;越看越觉得别扭&#xff1f;明明功能跑通了&#xff0c;但逻辑绕来绕去、变量命名像谜语、注释比代码还少——改它吧&#xff0c…

作者头像 李华
网站建设 2026/4/23 9:47:19

Qwen3-4B部署一文详解:GPU利用率提升60%的Streamlit优化方案

Qwen3-4B部署一文详解&#xff1a;GPU利用率提升60%的Streamlit优化方案 1. 为什么是Qwen3-4B-Instruct-2507&#xff1f;轻量不等于妥协 你可能已经试过不少大模型本地部署方案&#xff0c;但总在几个关键点上卡住&#xff1a;显存爆满、响应慢得像在等咖啡煮好、界面卡顿到…

作者头像 李华