文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

Xterm.js是什么及怎么使用

2023-07-04 13:19

关注

这篇文章主要介绍“Xterm.js是什么及怎么使用”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Xterm.js是什么及怎么使用”文章能帮助大家解决问题。

xterm.js是什么?

xterm是一个使用TypeScript编写的前端终端组件。并在Vscode等热门项目中得到了应用

安装

npm install xterm

初始化

// 初始化终端import { Terminal } from 'xterm'import 'xterm/dist/xterm.css'let term = new Terminal()// 将term挂砸到dom节点上term.open(document.getElementById('app'))term.write('Hello from \x1B[1;3;31mxterm.js\x1B[0m $ ')

使用插件

插件为javascript的模块可以扩展Terminal的原型

import { Terminal } from 'xterm';import * as fit from 'xterm/lib/addons/fit/fit'// 扩展TerminalTerminal.applyAddon(fit)let term = new Terminal()term.open(document.getElementById('#terminal'))// 使用fit方法term.fit()

API文档模块

xterm

这里包含了xterm.js的类型声明文件d.ts

type alias FontWeight

终端的字体粗细

type alias RendererType

终端的渲染方式, dom渲染或者是canvas渲染

类 Terminal

构造函数 constructor

创建一个新的Terminal对象

// 参数类型, 需要ITerminalOptions接口的定义// 返回Terminal类型new Terminal(options?: ITerminalOptions): Terminal

终端窗口的列数, 可以在创建Terminal指定cols

// 终端中每一行最多一列let term = new Terminal({ cols: 1 })
// 终端挂载的Dom元素term.element

终端的所有标记

终端窗口的行数, 可以在创建Terminal指定rows

let term = new Terminal({ rows: 30 })

返回, 接受终端输入的textarea的dom节点

Natural language strings that can be localized.

Adds a handler for CSI escape sequences.

向终端添加事件监听器, 并返回可用于删除事件监听器的对象, 对象中dispose属性的方法可以取消监听。支持的事件参考off方法的内容。

// 终端添加focus事件的监听, dispose函数可以取消监听const { dispose } = term.addDisposableListener('focus', function () {  console.log('focus')  dispose()})

添加标记, addMarker接受一个数字作为参数, 数字表示当前光标到标记y的偏移量,并返回标记。

let buffer = term.addMarker(cursorYOffset: number): IMarkerlet term = new Terminal()term.open(document.getElementById('app'))term.write('Hello from \x1B[1;3;31mxterm.js\x1B')term.addMarker(0)term.addMarker(1)// 返回两个标记console.log(term.markers)

Adds a handler for OSC escape sequences.

Attaches a custom key event handler which is run before keys are processed, giving consumers of xterm.js ultimate control as to what keys should be processed by the terminal and what keys should not.

Deregisters the character joiner if one was registered. NOTE: character joiners are only used by the canvas renderer.

Deregisters a link matcher if it has been registered.

使终端失焦

清除整个终端, 只保留当前行

选择终端内的所有文本

选中指定的两个指定行之间的终端文本

term.write('Hello from \x1B[1;3;31mxterm.js\x1B')term.selectLines(0, 0)

方法 clearSelection 清除当前选择的终端(只是清除选择的内容, 而非清除终端)

方法 destroy 销毁终端, 不推荐使用。推荐使用dispose()

方法 dispose 销毁终端

方法 focus 终端获得焦点

方法 getOption 获取的终端的配置选项, 需要指定配置的key

let term = new Terminal({  fontWeight: '800',  fontSize: 20})term.open(document.getElementById('app'))term.write('Hello from \x1B[1;3;31mxterm.js\x1B')// '800'console.log(term.getOption('fontWeight'))// 20console.log(term.getOption('fontSize'))

详细的类型推导请参考下图

Xterm.js是什么及怎么使用

获取当前终端选择的内容。(鼠标光标选中的内容)

判断当前终端是否有选中的内容。(鼠标光标选中的内容)

Xterm.js是什么及怎么使用

删除事件监听, 支持的方法见上图

Xterm.js是什么及怎么使用

添加事件监听, 支持注册的事件如上图

方法 open 打开终端。(xterm必须挂载dom完成)

方法 refresh 刷新指定两行之间的内容

Registers a character joiner, allowing custom sequences of characters to be rendered as a single unit. This is useful in particular for rendering ligatures and graphemes, among other things.

Each registered character joiner is called with a string of text representing a portion of a line in the terminal that can be rendered as a single unit. The joiner must return a sorted array, where each entry is itself an array of length two, containing the start (inclusive) and end (exclusive) index of a substring of the input that should be rendered as a single unit. When multiple joiners are provided, the results of each are collected. If there are any overlapping substrings between them, they are combined into one larger unit that is drawn together.

All character joiners that are registered get called every time a line is rendered in the terminal, so it is essential for the handler function to run as quickly as possible to avoid slowdowns when rendering. Similarly, joiners should strive to return the smallest possible substrings to render together, since they aren’t drawn as optimally as individual characters.

NOTE: character joiners are only used by the canvas renderer.

Registers a link matcher, allowing custom link patterns to be matched and handled.

方法 reset 重置整个终端

方法 resize 调整终端的大小, 参数为指定的col, row

方法 scrollLines 控制终端滚动条的滚动的行数(正数向下滚动, 负数向上滚动)

方法 scrollPages 滚动的页面树(正数向下滚动, 负数向上滚动)

方法 scrollToBottom 滚动到底部

方法 scrollToLine 滚动到具体的行

方法 scrollToTop 滚动到顶部

方法 setOption 设置终端的配置

具体的配置请参考下图

Xterm.js是什么及怎么使用

方法 writeln 向终端写入文本并换行

方法 write 向终端写入文本

静态方法 applyAddon

添加插件到终端的原型上

接口

这里没有什么好翻译的了, Xterm.js是由TypeScript编写。这里定义Xterm内部以及外部参数和返回值的iterface

插件

attach插件

attach可以将终端附加到websocket流中。Terminal实例会捕获所有键盘和鼠标事件并通过socket发送给后端

import * as Terminal from 'xterm';import * as attach from 'xterm/lib/addons/attach/attach';// 添加attach插件Terminal.applyAddon(attach);var term = new Terminal();var socket = new WebSocket('wss://docker.example.com/containers/mycontainerid/attach/ws');term.attach(socket)

方法 attach

// socket socoket实例// bidirectional 终端是否向套接字发送数据// bufferred 终端是否缓冲输出获得更好的性能attach(socket: WebSocket, bidirectional: Boolean, bufferred: Boolean)

方法 detach

// 分离当前终端和scoketdetach(socket)

fit 调整终端的大小以及行和列适配父级元素

fullscreen

fullscreen插件提供了设置全屏终端的toggleFullScreen方法, toggleFullScreen接受Boolean类型的值, 设置是否全屏展示终端

前后端示例

// 前端代码import { Terminal } from 'xterm'import 'xterm/dist/xterm.css'import io from 'socket.io-client';const socket = io('http://localhost:3000');let term = new Terminal({  fontSize: 30})term.open(document.getElementById('app'))socket.on('concat', function (data) {  socket.emit('run', { xml: `    #include <iostream>    using namespace std;    int main()    {        cout << "Nice to meet you.";        return 0;    }  `})  socket.on('writeIn', function (xml) {    term.writeln(xml)  })})
// 后端代码const Koa = require('koa')const Router = require('koa-router')const app = new Koa()const router = new Router()const server = require('http').createServer(app.callback())const io = require('socket.io')(server)const json = require('koa-json')const onerror = require('koa-onerror')const bodyparser = require('koa-bodyparser')const logger = require('koa-logger')const config = require('./config')const routes = require('./routes')onerror(app)app.use(bodyparser())  .use(json())  .use(logger())  .use(router.routes())  .use(router.allowedMethods())routes(router)io.on('connection', function (socket) {  socket.emit('concat');  socket.on('run', function () {    socket.emit('writeIn', '编译成功')    socket.emit('writeIn', '代码运行结束')  })})app.on('error', function(err, ctx) {  logger.error('server error', err, ctx)})module.exports = server.listen(config.port, () => {  console.log(`Listening on http://localhost:${config.port}`)})s

关于“Xterm.js是什么及怎么使用”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识,可以关注编程网行业资讯频道,小编每天都会为大家更新不同的知识点。

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯