0

0

JsTraceToIX - 调试 React、Vue 和 Nodejs 变得更容易! – 无需用“consolelog”弄乱您的代码库!

碧海醫心

碧海醫心

发布时间:2024-10-17 08:36:02

|

321人浏览过

|

来源于dev.to

转载

jstracetoix - 调试 react、vue 和 nodejs 变得更容易! – 无需用“consolelog”弄乱您的代码库!

如果您曾经需要在 node 或 web 浏览器上调试 react 或 vue 组件、箭头函数或复杂表达式,您就会知道添加多个 console.log 语句和进行不必要的代码更改的痛苦。这就是 jstracetoix 发挥作用的地方!

项目链接

主要特点:

  • 通过最少的代码更改来简化调试
  • 支持 react、vue 和 node.js 环境以及常规浏览器的调试。
  • 轻松处理单行表达式箭头函数
  • 轻松定义名称、过滤结果并覆盖输入和输出以实现更好的可追溯性。
  • 简单的函数名称,如 c__ 和 d__,可以在捕获错误后轻松发现并删除痕迹。
  • 多线程环境无缝协作。

奖励:如果您使用 python,请查看 pytracetoix,它为您的 python 项目提供了同样强大的调试工具。

立即学习前端免费学习笔记(深入)”;

告别复杂、凌乱的调试——使用 jstracetoix,您可以一步捕获输入并显示结果,让调试更干净、更快!

查看 jstracetoix 并了解它如何简化您的调试过程。

‎ Gemini Storybook
‎ Gemini Storybook

Google Gemini推出的AI绘本生成工具

下载

安装

environment require installation
browser no
node.js yes
react optional
vue yes
npm install jstracetoix --save-dev

反应用法

在此示例中:

  • citytax 箭头函数捕获输入价格并将其命名为“price”。
  • 关于 shoppinglist 功能:
    • c__ 捕获第一个 <td> 中的标题。
    • c__ 捕获 citytax 的输出,并在第二个 <td> 中将其命名为 citytax。
    • d__ 在一行中显示聚合信息:标题、价格、城市税、总价。

d__ 将生成以下输出:

i0:`rice` | price:`10` | citytax:`5` | _:`15`
i0:`coffee` | price:`30` | citytax:`15` | _:`45`
i0:`shoes` | price:`100` | citytax:`15` | _:`115`
import './app.css';
// without local installation
import { c__, d__ } from 'https://cdn.jsdelivr.net/gh/a-bentofreire/jstracetoix@1.1.0/component/jstracetoix.mjs';

// if it's installed locally via "npm install jstracetoix --save-dev"
// import { c__, d__ } from 'jstracetoix/component/jstracetoix.mjs';

const citytax = (price) => c__(price, {name: 'price'}) > 20 ? 15 : 5;
const products = [
    { title: 'rice', price: 10, id: 1 },
    { title: 'coffee', price: 30, id: 2 },
    { title: 'shoes', price: 100, id: 3 },
];

function shoppinglist() {
    const listitems = products.map(product =>
        <tr key={product.id}>
            <td>{c__(product.title)}</td>
            <td>{d__(product.price + c__(citytax(product.price), { name: 'citytax' }))}</td>
        </tr>
    );

    return (
        <table><tbody>{listitems}</tbody></table>
    );
}

function app() {
    return (
        <div classname="app">
            <header classname="app-header">
                <shoppinglist />
            </header>
        </div>
    );
}

export default app;

node.js 用法

在此示例中:

  • c__.allow() - 当值 > 40.00 时覆盖正在调试的输入值, 对于其他值,它不会捕获输入。
  • d__.allow() - 覆盖正在调试的结果值。
  • d__.after() - 显示结果和捕获的字段后停止程序。
import { c__, d__ } from 'jstracetoix';

const products = [
    { "name": "Smartphone 128GB", "price": 699.00 },
    { "name": "Coffee Maker", "price": 49.99 },
    { "name": "Electric Toothbrush", "price": 39.95 },
    { "name": "4K Ultra HD TV", "price": 999.99 },
    { "name": "Gaming Laptop", "price": 1299.00 }];

const factor = (price) => price < 1000 ? 1.10 : 1;

const prices = d__(products.map(product => c__(product.price,
    {
        allow: (index, name, value) => value > 40.00 ?
            Math.floor(value * factor(value)) : false,
        name: product.name.substring(0, 10)
    })), {
    allow: (data) => data._.map((v, i) => `${i}:${v}`),
    after: (data) => process.exit() // exits after displaying the results
});
// Smartphone:`768` | Coffee Mak:`54` | 4K Ultra H:`1099` | Gaming Lap:`1299` | _:`["0:699","1:49.99","2:39.95","3:999.99","4:1299"]`

// this code is unreachable
for (const price in prices) {
    let value = price;
}

输出

environment default output function
browser console.debug
node.js process.stdout
react console.debug
vue console.debug

除 node.js 环境外,输出显示在浏览器开发者工具的“控制台选项卡”下。
由于输出是使用 console.debug 生成的,因此可以轻松地从常规 console.log 消息中过滤掉它。

可以使用 init__({'stream': new_stream.log })

覆盖默认输出函数

元数据

d__ 函数回调允许,before 和 after 将接收一个参数数据,其中包含允许的输入以及以下元项:

  • meta__:元键列表,包括名称键。
  • thread_id__: 正在执行的thread_id
  • allow_input_count__: 允许输入的总数。
  • input_count__:捕获的输入总数。
  • allow__:如果为 false,则允许。在回调后使用它。
  • output__:传递给之前的文本,不带 new_line。
  • 名称:名称参数

文档

软件包文档

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
require的用法
require的用法

require的用法有引入模块、导入类或方法、执行特定任务。想了解更多require的相关内容,可以阅读本专题下面的文章。

510

2023.11.27

线程和进程的区别
线程和进程的区别

线程和进程的区别:线程是进程的一部分,用于实现并发和并行操作,而线程共享进程的资源,通信更方便快捷,切换开销较小。本专题为大家提供线程和进程区别相关的各种文章、以及下载和课程。

786

2023.08.10

Python 多线程与异步编程实战
Python 多线程与异步编程实战

本专题系统讲解 Python 多线程与异步编程的核心概念与实战技巧,包括 threading 模块基础、线程同步机制、GIL 原理、asyncio 异步任务管理、协程与事件循环、任务调度与异常处理。通过实战示例,帮助学习者掌握 如何构建高性能、多任务并发的 Python 应用。

379

2025.12.24

java多线程相关教程合集
java多线程相关教程合集

本专题整合了java多线程相关教程,阅读专题下面的文章了解更多详细内容。

33

2026.01.21

C++多线程相关合集
C++多线程相关合集

本专题整合了C++多线程相关教程,阅读专题下面的的文章了解更多详细内容。

31

2026.01.21

C# 多线程与异步编程
C# 多线程与异步编程

本专题深入讲解 C# 中多线程与异步编程的核心概念与实战技巧,包括线程池管理、Task 类的使用、async/await 异步编程模式、并发控制与线程同步、死锁与竞态条件的解决方案。通过实际项目,帮助开发者掌握 如何在 C# 中构建高并发、低延迟的异步系统,提升应用性能和响应速度。

105

2026.02.06

C++多线程并发控制与线程安全设计实践
C++多线程并发控制与线程安全设计实践

本专题围绕 C++ 在高性能系统开发中的并发控制技术展开,系统讲解多线程编程模型与线程安全设计方法。内容包括互斥锁、读写锁、条件变量、原子操作以及线程池实现机制,同时结合实际案例分析并发竞争、死锁避免与性能优化策略。通过实践讲解,帮助开发者掌握构建稳定高效并发系统的关键技术。

2

2026.03.16

js正则表达式
js正则表达式

php中文网为大家提供各种js正则表达式语法大全以及各种js正则表达式使用的方法,还有更多js正则表达式的相关文章、相关下载、相关课程,供大家免费下载体验。

531

2023.06.20

C++多线程并发控制与线程安全设计实践
C++多线程并发控制与线程安全设计实践

本专题围绕 C++ 在高性能系统开发中的并发控制技术展开,系统讲解多线程编程模型与线程安全设计方法。内容包括互斥锁、读写锁、条件变量、原子操作以及线程池实现机制,同时结合实际案例分析并发竞争、死锁避免与性能优化策略。通过实践讲解,帮助开发者掌握构建稳定高效并发系统的关键技术。

2

2026.03.16

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Sass 教程
Sass 教程

共14课时 | 1.0万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.6万人学习

CSS教程
CSS教程

共754课时 | 43.7万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号