首页 > 其他分享 >终端效果

终端效果

时间:2024-01-03 11:05:39浏览次数:36  
标签:string 效果 void xterm number 终端 data x1b


这里写自定义目录标题

vue3 + xterm + websocket实现web页面终端效果
            1、安装 xterm 、xterm-addon-attach、xterm-addon-fit,并引入
            2、预留dom节点
            3、new出Terminal的实例,并设置终端的样式
            4、websocket
            5、websocket 函数
            6、terminal相关配置
            7、内置函数 Apis
            8、相应函数
            全部代码

vue3 + xterm + websocket实现web页面终端效果

新项目需求,需要在页面上实现终端效果。如下 在这里插入图片描述

项目开始时,不理解,按回车键,删除键,等等都没效果,花费了大量的时间处理这些,以及删除报错的问题。这个地方需要注意一下,不需要对任何键做处理,交给后端处理,只需要把输入的值传给后端即可,后端会做处理,以及删除报错的问题。

1、安装 xterm 、xterm-addon-attach、xterm-addon-fit,并引入

import { Terminal } from "xterm" import { FitAddon } from "xterm-addon-fit" import { AttachAddon } from 'xterm-addon-attach'

1
2
3

2、预留dom节点


1
2
3
4
5

3、new出Terminal的实例,并设置终端的样式

const initTerm = () => { // 设置终端的样式 data.term = new Terminal({ rendererType: "dom", //渲染类型 convertEol: true, //启用时,光标将设置为下一行的开头 // scrollback: 10,//终端中的回滚量 fontSize: 16, //字体大小 disableStdin: false, //是否应禁用输入。 cursorStyle: "block", //光标样式 // cursorBlink: true, //光标闪烁 scrollback: 30, tabStopWidth: 4, theme: { foreground: "Consolas", //字体 background: "#060101", //背景色 cursor: "help" //设置光标 } })

data.term.focus()
data.term.open(document.getElementById("terminal"))

// 输入起始符“$”
data.term.prompt = () => {
  term.write("\r\n$ ");
};
data.term.prompt()
const fitAddon = new FitAddon()
data.term.loadAddon(fitAddon)

fitAddon.fit()
// 根据窗口变化自适应
function resizeScreen() {
    fitAddon.fit()
}
window.addEventListener("resize", resizeScreen)

// 把输入的值,通过socket传给后端
data.term.onData(function (val) {
    const msg = JSON.stringify({
        MsgType: 1,
        SubMsgType: 1,
        cmdProxy: val
    })
    if (data.socket.readyState == 1) {
        data.socket.send(msg)
    }
})

data.term.attachCustomKeyEventHandler(function (t) {
    let e

    if (t.ctrlKey) {
        if ("c" === t.key) {
            e = data.term

            if (e.hasSelection()) {
                return false
            } else {
                return true
            }
        }

        if ("v" === t.key) {
            return false
        }
    }

    return !["F9", "F10", "F11", "F12"].includes(t.key)
})

}

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72

4、websocket

const websockedInit = () => { if (location.protocol == "http:") { data.socket = new WebSocket("ws:\\" + window.location.host ") } else { data.socket = new WebSocket("wss:\\" + window.location.host") } socketOnClose() //关闭 socketOnOpen() // socketOnError() }

//成功之后操作 const socketOnOpen = () => { data.socket.onopen = () => { //通信建立成功后才会走这个函数 data.socket.onmessage = function (e) { // 拿到后端传递过来的数据 let msgData = JSON.parse(e.data) console.log("后端传过来的数据2", msgData) // 内部的判断逻辑字段,根据后端而定 if (msgData.suc== "success") { data.term.write(msgData.echoInfo) } else { data.term.write("failed") } } } } const socketOnClose = () => { data.socket.onclose = () => { console.log("close socket") } } const socketOnError = () => { data.socket.onerror = () => { console.log("socket error") } }

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36

5、websocket 函数

在这里插入图片描述 6、terminal相关配置

/**

  • 当 canvas 渲染器运行过慢时,会回退为 DOM 渲染器
  • DOM 渲染器下不起作用的功能: Letter spacing || Cursor blin */ rendererType?: 'dom' || 'canvas'; // 渲染器类型

cols?: number; // 列数 rows?: number; // 行数

disableStdin?: boolean; // 是否禁用输入

fontSize?: number; // 字体大小 fontFamily?: string; // 字体类型 fontWeight?: 'normal' | 'bold' | '100' | '200' | '300' | '400' | '500' | '600' | '700' | '800' | '900' | number; // 字体加粗 fontWeightBold?: 'normal' | 'bold' | '100' | '200' | '300' | '400' | '500' | '600' | '700' | '800' | '900' | number; // 字体加粗 letterSpacing?: number; // 字符间距 lineHeight?: number; // 字体行高

scrollback?: number; // 终端中的回滚量,即当前视口之上保留的行数 scrollSensitivity?: number; // 正常滚动的滚动速度 fastScrollModifier?: 'alt' | 'ctrl' | 'shift' | undefined; // 按住哪个键可倍增滚动速度 fastScrollSensitivity?: number; // 快速滚动的滚动速度

logLevel?: 'debug' | 'info' | 'warn' | 'error' | 'off'; 日志类型, 默认是 info allowTransparency?: boolean; // 背景是否应支持非不透明颜色,开启后支持 theme中使用 rgba theme?: { // 主题 cursor?: string; // 光标颜色 cursorAccent?: string; // 光标的强调色 foreground?: string; // 默认的前景色,即字体颜色 background?: string; // 默认的背景色 selection?: string; // 选择的背景色(可以是透明的) // 颜色: 使用 ANSI 编码 black?: string; // x1b[30m red?: string; // x1b[31m green?: string; // x1b[32m yellow?: string; // x1b[33m blue?: string; // x1b[34m magenta?: string; // x1b[35m cyan?: string; // x1b[36m white?: string; // \x1b[37m brightBlack?: string; // \x1b[1;30m brightRed?: string; // \x1b[1;31m brightGreen?: string; // \x1b[1;32m brightYellow?: string; // \x1b[1;33m brightBlue?: string; // \x1b[1;34m brightMagenta?: string; // \x1b[1;35m brightCyan?: string; // \x1b[1;36m brightWhite?: string; // \x1b[1;37m };

bellStyle?: 'none' | 'sound'; // 终端将使用的铃声通知类型 bellSound?: string; // 当 bellStyle='sound' 时,用于 sound 的数据URI

convertEol?: boolean; // 启用时,光标将设置为每一新行下一行的开头 cursorBlink?: boolean; // 光标是否闪烁 cursorStyle?: 'block' | 'underline' | 'bar'; // 光标的样式 cursorWidth?: number; // cursorStyle='bar' 时光标的宽度(以px为单位) altClickMovesCursor?: boolean; // 如果启用,alt+click会将提示光标移动到鼠标下方的位置。默认值为true

/**

  • 终端中文本的最小对比度,设置该值将根据是否满足对比度动态更改前景颜色
  • Example values:
  • 1: The default, do nothing.
  • 4.5: WCAG AA合规性的最低要求
  • 7: WCAG AAA合规性的最低要求
  • 21: 黑纸白字或白纸黑字 */ minimumContrastRatio?: number; drawBoldTextInBrightColors?: boolean; // 是否以明亮的颜色绘制粗体文本。默认值为true wordSeparator?: string; // 字符被双击的时候单独被选中,多个字符可以用空格间隔 rightClickSelectsWord?: boolean; // 是否支持鼠标右键选中整行 screenReaderMode?: boolean; // 是否启用屏幕阅读器支持

allowProposedApi?: boolean; // 是否允许使用建议的API, 如果为false,则任何标记为实验性/建议性的API的使用都将抛出错误 /**

  • Whether holding a modifier key will force normal selection behavior,
  • regardless of whether the terminal is in mouse events mode. This will
  • also prevent mouse events from being emitted by the terminal. For
  • example, this allows you to use xterm.js' regular selection inside tmux
  • with mouse mode enabled.
  • 无论终端是否处于鼠标事件模式,按住修改器键是否将强制执行正常选择行为。这也将防止终端发出鼠标事件。例如,这允许您在启用鼠标模式的情况下在tmux中使用xterm.js的常规选择。 / macOptionClickForcesSelection?: boolean; linkTooltipHoverDuration?: number; // 在链接上悬停时触发链接工具提示事件之前的持续时间(毫秒),将被弃用 macOptionIsMeta?: boolean; // 是否将选项视为元键 tabStopWidth?: number; // 终端中制表位的大小 /*
  • 是否启用“Windows模式”。由于Windows后端winpty和conpty通过在其一侧进行换行操作,因此xterm.js无法访问换行。
  • Whether "Windows mode" is enabled. Because Windows backends winpty and
  • conpty operate by doing line wrapping on their side, xterm.js does not
  • have access to wrapped lines. When Windows mode is enabled the following
  • changes will be in effect:
  • Reflow is disabled.
  • Lines are assumed to be wrapped if the last character of the line is
  • not whitespace. / windowsMode?: boolean; /*
  • 启用各种窗口操作和报告功能。
  • 出于安全原因,默认情况下禁用所有功能。 */ windowOptions?: IWindowOptions;
    1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103

7、内置函数 Apis

open(HTMLElement): void; // Terminal基于传入的 dom 元素进行初始化 dispose(): void; // Terminal销毁,同时也会销毁 dom 元素以及事件 reset(): void; // Terminal reset

getOption(key: string): any; // 获取配置 setOption(key: string, value: any): void; // 动态设置配置

focus(): void; // Terminal聚焦 blur(): void; // Terminal失焦 resize(columns: number, rows: number): void; // 可以动态设置行数和列数

write(data: string | Uint8Array, callback?: () => void): void; // xterm终端写入 writeln(data: string | Uint8Array, callback?: () => void): void; writeUtf8(data: Uint8Array, callback?: () => void): void; clear(): void; // 清空光标所在行上面的所有输入内容,不包含删除当前光标所在行

select(column: number, row: number, length: number): void; // 选择第row + 1 行的 第 column + 1 列开始,直到后面的第 length 个字符 selectAll(): void; // 选中全部内容 selectLines(start: number, end: number): void; // 可以配合 onRender 方法的回调选中 hasSelection(): boolean; // 判断有没有选中 getSelection(): string; // 获取选中的字符 getSelectionPosition(): {startColumn: number, startRow: number, endColumn: number, endRow: number} | undefined; // 获取选中的字符的位置 clearSelection(): void; // 清除选中状态

scrollLines(amount: number): void; // 一次滚动 amount 行 scrollPages(pageCount: number): void; // 相当于鼠标滚轮滑了pageCount下 scrollToTop(): void; // 滚动到顶部 scrollToBottom(): void; // 滚动到底部 scrollToLine(line: number): void; // 滚动到第 line + 1 行是当前窗口的第一行

refresh(start: number, end: number): void; // 范围内 refresh loadAddon(addon: ITerminalAddon): void; // 挂载插件

// 以下均无测试使用 paste(data: string): void; // 用了,没啥反应 registerMarker(cursorYOffset: number): IMarker | undefined; // 注册标记,不会用 addMarker(cursorYOffset: number): IMarker | undefined; // 添加标记,不会用

attachCustomKeyEventHandler(customKeyEventHandler: (event: KeyboardEvent) => boolean): void; // 键盘的自定义事件 registerLinkMatcher(regex: RegExp, handler: (event: MouseEvent, uri: string) => void, options?: ILinkMatcherOptions): number; deregisterLinkMatcher(matcherId: number): void; registerLinkProvider(linkProvider: ILinkProvider): IDisposable;

registerCharacterJoiner(handler: (text: string) => [number, number][]): number; deregisterCharacterJoiner(joinerId: number): void;

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46

8、相应函数

onKey(callback({ key: string, domEvent: KeyboardEvent })) // key: 键盘按键的值,domEvent: 键盘事件 onData(callback(key: String)) // 类似于input的oninput事件,key代表的是输入的字符 onCursorMove(callback()) // 输入光标位置变动会触发,比如输入,换行等 onLineFeed(callback()) // 操作回车按钮换行时触发,自然输入换行不会触发 onScroll(callback(scrollLineNumber: number)) // 当输入的行数超过设定的行数后会触发内容的滚动,输入换行以及回车换行均会触发 onSelectionChange(callback()) // 操作鼠标左键选中/取消选中会触发 onRender(callback({start: number, end: number})) // 鼠标移出点击,移入点击以及输入模式下键盘按下都会触发,范围从“0”到“Terminal.rows-1” onResize(callback({cols: number, rows: number})) // 在 open() 之后如果调用 resize 设置行列会触发改事件,返回新的行列数值

onTitleChange(callback()) // 标题更改触发,未找到对应的触发条件 onBell(callback()) // 为触发铃声时添加事件侦听器

1
2
3
4
5
6
7
8
9
10
11
12

全部代码

需求要以弹框的形式展示终端页面


———————————————— 版权声明:本文为CSDN博主「人称代词」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。 原文链接:https://blog.csdn.net/qq_46217368/article/details/132607439

标签:string,效果,void,xterm,number,终端,data,x1b
From: https://blog.51cto.com/u_15591779/9079185

相关文章

  • MT8766核心板_基于联发科MTK8766安卓核心板的手持终端解决方案
    MT8766安卓核心板采用联发科MTK8766四核4G模块方案,是一款集成安卓系统的一体板。它具备四核芯片架构,主频高达2.0GHz,支持国内4G全网通,采用12nm制程工艺,兼容谷歌Android9.0系统。MT8766安卓核心板还配备了功能强大的IMGGE8300GPU,主频达到600MHz。其内存支持4GB,摄像头......
  • 揭秘漫途遥测终端的功能及应用
    遥测终端是一种集数据采集、远程传输、数据存储与处理于一体的综合性设备。在物联网应用领域,遥测终端已逐渐成为现代智能物联领域中不可或缺的一部分。遥测终端的功能1.多参数监测:多参数遥测终端能够实时监测各种环境参数,如温度、湿度、压力、风速等,实现对环境参数的实时监测和控制......
  • 【每日随笔】情绪操控术 ① ( 三层大脑模型 - 爬行脑 / 情绪脑 / 理性脑 | 情绪脑负面
    文章目录一、三层大脑模型1、三层大脑的进化2、三层大脑的分层包裹关系二、情绪脑的负面效果1、情绪脑VS理性脑2、情绪脑功能3、情绪脑负面效果一、三层大脑模型1、三层大脑的进化人的大脑是几亿年来逐步进化出来的,不同的脑区产生的时间是不同的;爬行脑进化了3亿年......
  • 美团到店终端从标准化到数字化的演进之路
    总第580篇| 2023年第032篇本文整理自美团技术沙龙第76期《大前端研发协同效能提升与实践》。前端团队在产研多角色协同形式上存在不同阶段,而大前端多技术栈在各阶段都有其独特的实践,同时又有类似的演进路线。本文从到店终端团队移动端和前端技术栈持续交付演进历程展开,分享了大前......
  • uniAPP IOS 端关闭滚动回弹效果
    进入pages.josn文件找到想要禁止回弹的页面,在对应的style中添加以下代码:{ //我的页 "path":"pages/mine/mine", "style":{ "navigationBarTitleText":"", "navigationStyle":"custom",//隐藏系统导航栏 &quo......
  • linux 终端使用 printf 命令
     001、输出字符串[root@pc1test1]#ls[root@pc1test1]#printf"helloworld\n"##方法一helloworld[root@pc1test1]#printf"%s\n""helloworld"##方法二helloworld 002、输出整型[root@pc1test1]#ls[root@pc1test1]#pr......
  • 数据库超线程效果的一个验证
    数据库超线程效果的一个验证背景元旦加班期间,一直跟着同事再查一个项目的卡顿问题.自己想到了一个提高测试环境性能的方法.然后趁着元旦用的人少进行了一下验证.在业务空闲期间,批量进行Oracle数据库的统计信息更新动作.自己一开始担心的是如果数据量很大,执行时......
  • 如何利用多开软件在Windows电脑上优化游戏效果?
    当今,许多玩家都希望在Windows电脑上通过多开软件来优化游戏效果。多开软件可以让玩家同时在一台电脑上打开多个游戏实例,从而提升游戏体验和效率。接下来,我将为大家介绍如何在Windows电脑上利用多开软件来优化游戏效果。首先,选择合适的多开软件非常重要。目前市面上有许多多开软件......
  • PyCharm 中执行命令提示 command not found(终端运行appium正常)
    前提本地终端中执行adb或者其它命令是ok的复制本地的$PATH值打开终端或者iTerm执行命令echo$PATH 打开PyCharm替换下PyCharm中的$PATH值即可(EditConfigurations-->Environmentvariables)  PATH换成appium的安装路径#查看路径,终端运行whichappium 正......
  • 车载导航定制_智能车载终端安卓主板硬件解决方案
    智能车载一直是司机出行的得力助手,而集成了诸多强大功能的车载导航更是为驾驶者提供了更全面的驾驶辅助体验。从车辆行车记录、倒车影像,到AR实景导航、语音助手、ADAS辅助,再到云电子狗、蓝牙通话、影音娱乐等功能,这款车载导航系统为驾驶者带来了无与伦比的出行新体验。基于......