vue3+tpescript 点击按钮跳转新页面直接通过链接预览word

1.在route里面配置 跳转页面

javascript 复制代码
{
		path: '/helpManual',
		name: 'staticRoutes.helpManual',
		component: () => import('/@/views/shiftHandover/helpManual.vue'),
		meta: {
			isHide: true,
			isAuth: false,
			isKeepAlive: false
		},
	}

2.通过点击 openHelpManual跳转新页面

html 复制代码
<el-tooltip content="帮助手册" placement="top">
            <el-icon style="margin-left: 10px; cursor: pointer; font-size: 18px; color: #409eff;"
                     @click="openHelpManual">
              <QuestionFilled/>
            </el-icon>
          </el-tooltip>
path: '/helpManual' 页面路径 在route配置
TypeScript 复制代码
//打开帮助手册
const openHelpManual = () => {
  // 跳转到新页面显示Word文档
  const url = router.resolve({
    path: '/helpManual'
  }).href;
  window.open(url, '_blank');
}

3.helpManual页面

注意我这里在vite.config.ts 配置了代理,因为我兼容本地调试,

host 为动态获取主机名

若不需要 直接docUrl.value = '地址'就可以

TypeScript 复制代码
<template>
  <div class="help-manual-container">
    <div style="height: 100vh; overflow: auto;">
      <VueOfficeDocx
        v-if="docUrl"
        :src="docUrl"
        style="height: 100%;"
        @error="handleDocxError"
      />
    </div>
  </div>
</template>

<script setup lang="ts" name="helpManual">
import { ref, onMounted } from 'vue';
import VueOfficeDocx from '@vue-office/docx';
import '@vue-office/docx/lib/index.css';
import { useMessage } from '/@/hooks/message';

// 根据window.location.host动态设置帮助手册URL
const getHelpManualUrl = () => {
  const host = window.location.host
  // 直接判断主机名是否包含localhost或100.100.100.207
  if (host.includes('localhost') || host.includes('100.100.100.207')) {
    // 使用相对路径通过代理访问,避免CORS问题
    return '/doc/JjbOperationManual.docx'
  }
  // 其他情况直接使用当前host
  return `http://${host}/doc/JjbOperationManual.docx`
}

const docUrl = ref('');

onMounted(() => {
  // 直接使用URL地址
  console.log('URL地址:',getHelpManualUrl())
  docUrl.value = getHelpManualUrl();
});

//Word文档加载错误
const handleDocxError = (error: any) => {
  console.error('Word文档加载错误:', error);
  useMessage().error('文档加载失败,请检查网络连接或文档地址。');
};
</script>

<style scoped>
.help-manual-container {
  width: 100%;
  height: 100vh;
  background: #fff;
}
</style>
相关推荐
击败不可能2 小时前
vue做任务工具方法的实现
前端·javascript·vue.js
觉醒大王2 小时前
医学好投的普刊分享
前端·论文阅读·深度学习·学习·自然语言处理·学习方法
小二·2 小时前
Python Web 开发进阶实战:AI 编排引擎 —— 在 Flask + Vue 中构建低代码机器学习工作流平台
前端·人工智能·python
【赫兹威客】浩哥2 小时前
【赫兹威客】框架模板-前端bat脚本部署教程
前端·vue.js
sww_10263 小时前
智能问数系统(二):数据分析师Python
java·前端·python
一 乐3 小时前
学生宿舍管理|基于springboot + vue学生宿舍管理系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·后端·助农电商系统
一人の梅雨3 小时前
义乌购商品详情接口进阶实战:批发场景下的精准解析与高可用架构
java·服务器·前端
bin91533 小时前
(文后附完整代码)html+css+javascript 弓箭射击游戏项目分析
前端·javascript·css·游戏·html·前端开发
翱翔的苍鹰3 小时前
完整的“RNN + jieba 中文情感分析”项目的Gradio Web 演示的简单项目
前端·人工智能·rnn