共计 1069 个字符,预计需要花费 3 分钟才能阅读完成。
安装 novnc
yarn add @novnc/novnc
npm i @novnc/novnc
具体用法可以参阅官方文档
https://github.com/novnc/noVN…
在 vue 里面使用
- template
<template> | |
<div id="screen"> | |
// 虚拟化桌面将已 canvas 的形式被渲染到这里 | |
</div> | |
</template> |
- script
import RFB from '@novnc/novnc/core/rfb'; | |
export default { | |
name: 'novnc', | |
data () { | |
rfb:null, | |
url: undefined, // 链接的 url | |
IsClean: false, // 是否已断开并不可重新连接 | |
connectNum:0 // 重连次数 | |
}, | |
methods: { | |
// vnc 连接断开的回调函数 | |
disconnectedFromServer (msg) {if(msg.detail.clean){ | |
// 根据 断开信息的 msg.detail.clean 来判断是否可以重新连接 | |
this.contentVnc()} else {// 这里做不可重新连接的一些操作} | |
}, | |
// 连接成功的回调函数 | |
connectedToServer() {console.log('success') | |
}, | |
// 连接 vnc 的函数 | |
connectVnc () { | |
const PASSWORD = ''; | |
let rfb = new RFB(document.getElementById('screen'), this.url, { | |
// 向 vnc 传递的一些参数,比如说虚拟机的开机密码等 | |
credentials: {password: password} | |
}); | |
rfb.addEventListener('connect', this.connectedToServer); | |
rfb.addEventListener('disconnect', this.disconnectedFromServer); | |
rfb.scaleViewport = true; //scaleViewport 指示是否应在本地扩展远程会话以使其适合其容器。禁用时,如果远程会话小于其容器,则它将居中,或者根据 clipViewport 它是否更大来处理。默认情况下禁用。rfb.resizeSession = true; // 是一个 boolean 指示是否每当容器改变尺寸应被发送到调整远程会话的请求。默认情况下禁用 | |
this.rfb = rfb; | |
} | |
}, | |
在 mounted 周期里面连接 vnc | |
mounted () { | |
// 这时已经可以获取到 dom 元素 | |
this.connectVnc()} | |
} |
正文完
发表至: javascript
2019-10-15