vuepress引入vue-qr组件后build报错navigator is not defined问题
时间:2022-07-24
本文章向大家介绍vuepress引入vue-qr组件后build报错navigator is not defined问题,主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
记下vuepress引入外部组件后build报错问题
最近博客中集成了vue-qr组件用于生成访问的二维码.
组件安装
npm install vue-qr
自定义组件代码
Qrcode.vue
<template>
<div class="vue-qrcode-box">
<vue-qr :text="qrUrl" :size="114" :margin="5"></vue-qr>
</div>
</template>
<script>
import vueQr from 'vue-qr'
export default {
name: 'qr-code',
components: {
vueQr
},
data() {
return {
qrUrl: ''
}
},
mounted: function() {
const that = this
setTimeout(() => {
that.qrUrl = location.origin + that.$route.path
}, 0)
},
watch: {
$route(to, from) {
if (from.path != to.path) {
this.qrUrl = location.origin + this.$route.path
}
}
},
methods: {},
created() {}
}
</script>
<style scoped>
.vue-qrcode-box img {
width: 100%;
}
</style>
组件引用
如果直接引入会报如下错误
原因:所有的页面在生成静态 HTML 时都需要通过 Node.js 服务端渲染,所有的 Vue 相关代码都应当遵循 编写通用代码 的要求。 要确保只在
beforeMount
或者mounted
访问浏览器 / DOM 的 API。
如果一些组件或库在导入时就试图访问浏览器 API ,需要在合适的生命周期钩子中动态导入。
这里引用的 vue-qr
应该是使用了 navigator 的 API,所以就选择在单页的mounted里动态引入的方式来解决构建时的报错问题:
<template>
<component v-if="qrcode" :is="qrcode"></component>
</template>
<script>
export default {
data() {
return {
qrcode: null
}
},
mounted () {
import('./Qrcode').then(module => {
this.qrcode = module.default
})
}
}
</script>
效果
参考资料
- Web应用服务器安全:攻击、防护与检测
- 基于Go Packet实现网络数据包的捕获与分析
- 动态追踪技术(四):基于 Linux bcc/BPF 实现 Go 程序动态追踪
- Hive 时间转换函数使用心得
- Flume-Hbase-Sink针对不同版本flume与HBase的适配研究与经验总结
- 利用Flume 汇入数据到HBase:Flume-hbase-sink 使用方法详解
- 浅谈保证软件工程质量的一些心得体会
- 基于ELK的nginx-qps监控解决方案
- 2017年年度最烂密码排名
- 字符串方法汇总(三)
- 周鸿祎:“大安全”网络时代 需要AI大数据的技术支持
- 爆料:对扫码支付下手后,据说央行接下来要提高备付金,目标比例42%
- 回顾2017年5大科技突破,“时间晶体”充满想象!
- 1宽币=883?山本宽称要发行自己的数字货币
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法