IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> vue-显示linux日志乱码,web终端组 -> 正文阅读

[JavaScript知识库]vue-显示linux日志乱码,web终端组

工具

vue2.x + xterm.js

文档传送门:Xterm.js

问题描述:

系统中有要显示linux端日志的功能,后台去抓取,并用接口反回即可,但是它会有一些无符号字符串(\u001b),需要转换,可是又有一些类似"[1A"(linux平台下,用于控制颜色,格式等字符)特殊的字符,结果,我的输出内容就如下图所示,有些乱码

下图是应用了xterm.js后的对比,好在是没有乱码了。

1 安装? ?

注意:我是用cnpm方法安装的,有时候,Npm方法安装可能会报错,其实就是依赖中的某些版本问题,但还是根据自己的项目走即可

npm install xterm -s

插件:

fit:格式化插件,xterm.js本身是依赖于【列,行】的设置来控制宽度与高度且是固定死的,fit插件可以根据父元素来自适应你的界面

npm iinstall xterm-addon-fit -s

初始化代码,仅提取关键代码,后面组件里有完整代码

1 HTML部分
<div class="vi-console">
? ? ? ? <!-- terminal?-->
? ? ? ? <div class="console" id="terminal"></div>
</div>

....
==============================================================


2 加载默认资源
import { Terminal } from 'xterm'
import { FitAddon } from 'xterm-addon-fit';
import 'Xterm/css/xterm.css'

....
==============================================================

3 terminal窗体初始化,及自适应插件,初始化文字提示
const term = new Terminal() //初始化

const fitAddon = new FitAddon();//加载fit插件,仅用于窗口自适应
?term.loadAddon(fitAddon);

const myTerminal = document.getElementById('terminal') // DOM
term.open(myTerminal);

fitAddon.fit();//自适应界面

term.write('Hello from \x1B[1;3;31mxterm.js\x1B[0m $ ')//初始化显示字符串

term.focus();
==============================================================

以上代码搞定后,你会得到如下界面,文字是write(”“)方法内的文字,有些字符你得去官网看是什么含义,但基本就是转义字符?

?======================猥琐发育,别浪================================

2 组件代码

<template>
    <div class="vi-console">
        <!-- terminal窗体 -->
        <div class="console" id="terminal"></div>
    </div>
</template>
<script>
import { Terminal } from 'xterm'
import { FitAddon } from 'xterm-addon-fit';
import 'Xterm/css/xterm.css'

export default {
    name: 'ViConsole',
    props: {
        terminalOptions: {
            type: Object,
            default () {
                return {
                    pid: 1,
                    name: 'terminal',
                    //cols: 140,//总列宽度,会影响到整体宽度
                    logLevel: 'error',
                    windowsMode: true,
                    fontWeight: '300',
                    //lineHeight: 2,//行高
                    cursorStyle: 'underline',
                    wordSeparator: '……',
                    theme: {
                        //terminal窗体样式设置
                        background: '#0c0c0c',//背景
                        foreground:'#c2c2c2',//所有文字颜色
                        cursor: '#fff',//光标颜色
                        selection: '#868686'//选择后背景颜色
                    }
                }
            }
        },
        log: {
            type: String,
            default: ""//传入的日志字符串,linux日志
        },
    },
    data () {
        let _this = this
        return {
            term: new Terminal(_this.terminalOptions)
        }
    },
    mounted () {
        let _this = this
        
        // 我的项目排版有点小问题,如果不加settimeout,样式会跑偏,默认情况下,_this.initTerm()即可
        setTimeout(() => {
            _this.initTerm()
        }, 200);

    },
    watch: {
        log (newVal, oldVal) {
            let _this = this
            if (newVal && newVal.length != 0) {

                //写入内容
                _this.writeTerm(newVal)
            }
        }
    },
    methods: {
        writeTerm (str) {
            //写入内容
            let _this = this
            _this.term.write(str)
        },
        initTerm () {
            let _this = this

            const fitAddon = new FitAddon();
            _this.term.loadAddon(fitAddon);

            const myTerminal = document.getElementById('terminal')
            _this.term.open(myTerminal);
            fitAddon.fit();

            _this.writeTerm('Hello from \x1B[1;3;31mxterm.js\x1B[0m $ ')

            _this.term.focus();

            // window.addEventListener('resize', _this.initTerm );
        },
    },

    beforeDestroy () {
        let _this = this
        //this.terminalSocket.close()
        _this.term.dispose()
    }
}
</script>
<style scoped>
.vi-console {
    width: 100%;
    min-height: 240px;
}
</style>

3 应用组件

log:是你的linux日志字符串,接入你自己的API

<vi-consoleVue  :log="你的日志代码"></vi-consoleVue>

//示例字符串,自己改下即可
log: "\n\u001b[1A\r\r正在节点 peer0.jgr.llkj.com 查询已安装链码...................................../成功.\r\u001b[1B\u001b[1A\r\r正在节点 peer0.jgr.llkj.com 查询已安装链码..................................... 成功.\r\u001b[1B\n\u001b[1A\rLabel: cclabel0.6.4  PackageID: cclabel0.6.4:8836beb355d04f846b2ccad8c5c2788a79f1e99a5523abab67cb22a37c31960d\r\u001b[1B\n\u001b[1A\r\r正在节点 peer0.qy1.llkj.com 查询已安装链码...................................../成功.\r\u001b[1B\u001b[1A\r\r正在节点 peer0.qy1.llkj.com 查询已安装链码..................................... 成功.\r\u001b[1B\n\u001b[1A\rLabel: cclabel0.6.4  PackageID: cclabel0.6.4:8836beb355d04f846b2ccad8c5c2788a79f1e99a5523abab67cb22a37c31960d\r\u001b[1B\n\u001b[1A\r\r正在节点 peer0.qy2.llkj.com 查询已安装链码...................................../成功.\r\u001b[1B\u001b[1A\r\r正在节点 peer0.qy2.llkj.com 查询已安装链码..................................... 成功.\r\u001b[1B\n\u001b[1A\rLabel: cclabel0.6.4  PackageID: cclabel0.6.4:8836beb355d04f846b2ccad8c5c2788a79f1e99a5523abab67cb22a37c31960d\r\u001b[1B\n\u001b[1A\r\r正在节点 peer0.qy3.llkj.com 查询已安装链码...................................../成功.\r\u001b[1B\u001b[1A\r\r正在节点 peer0.qy3.llkj.com 查询已安装链码..................................... 成功.\r\u001b[1B\n\u001b[1A\rLabel: cclabel0.6.4  PackageID: cclabel0.6.4:8836beb355d04f846b2ccad8c5c2788a79f1e99a5523abab67cb22a37c31960d\r\u001b[1B"

结论:

? ? ? ? 我这个组件仅是显示一些Linux日志字符串功能,其实它还有很多方法,我暂时没应用上,如果你要开发web-shell组件,你就去官网好好看看其它API,开发完了记得共享哈!

  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2022-07-03 10:40:34  更:2022-07-03 10:43:41 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/11 9:59:22-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码