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 并了解它如何简化您的调试过程。

Anyword
Anyword

AI文案写作助手和文本生成器,具有可预测结果的文案 AI

下载

安装

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

反应用法

在此示例中:

  • citytax 箭头函数捕获输入价格并将其命名为“price”。
  • 关于 shoppinglist 功能:
    • c__ 捕获第一个 中的标题。
    • c__ 捕获 citytax 的输出,并在第二个 中将其命名为 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 =>
              
                  {c__(product.title)}
                  {d__(product.price + c__(citytax(product.price), { name: 'citytax' }))}
              
          );
      
          return (
              {listitems}
      ); } function app() { return (
      ); } 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。
      • 名称:名称参数

      文档

      软件包文档

相关专题

更多
python开发工具
python开发工具

php中文网为大家提供各种python开发工具,好的开发工具,可帮助开发者攻克编程学习中的基础障碍,理解每一行源代码在程序执行时在计算机中的过程。php中文网还为大家带来python相关课程以及相关文章等内容,供大家免费下载使用。

769

2023.06.15

python打包成可执行文件
python打包成可执行文件

本专题为大家带来python打包成可执行文件相关的文章,大家可以免费的下载体验。

661

2023.07.20

python能做什么
python能做什么

python能做的有:可用于开发基于控制台的应用程序、多媒体部分开发、用于开发基于Web的应用程序、使用python处理数据、系统编程等等。本专题为大家提供python相关的各种文章、以及下载和课程。

764

2023.07.25

format在python中的用法
format在python中的用法

Python中的format是一种字符串格式化方法,用于将变量或值插入到字符串中的占位符位置。通过format方法,我们可以动态地构建字符串,使其包含不同值。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

639

2023.07.31

python教程
python教程

Python已成为一门网红语言,即使是在非编程开发者当中,也掀起了一股学习的热潮。本专题为大家带来python教程的相关文章,大家可以免费体验学习。

1305

2023.08.03

python环境变量的配置
python环境变量的配置

Python是一种流行的编程语言,被广泛用于软件开发、数据分析和科学计算等领域。在安装Python之后,我们需要配置环境变量,以便在任何位置都能够访问Python的可执行文件。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

549

2023.08.04

python eval
python eval

eval函数是Python中一个非常强大的函数,它可以将字符串作为Python代码进行执行,实现动态编程的效果。然而,由于其潜在的安全风险和性能问题,需要谨慎使用。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

579

2023.08.04

scratch和python区别
scratch和python区别

scratch和python的区别:1、scratch是一种专为初学者设计的图形化编程语言,python是一种文本编程语言;2、scratch使用的是基于积木的编程语法,python采用更加传统的文本编程语法等等。本专题为大家提供scratch和python相关的文章、下载、课程内容,供大家免费下载体验。

709

2023.08.11

Java JVM 原理与性能调优实战
Java JVM 原理与性能调优实战

本专题系统讲解 Java 虚拟机(JVM)的核心工作原理与性能调优方法,包括 JVM 内存结构、对象创建与回收流程、垃圾回收器(Serial、CMS、G1、ZGC)对比分析、常见内存泄漏与性能瓶颈排查,以及 JVM 参数调优与监控工具(jstat、jmap、jvisualvm)的实战使用。通过真实案例,帮助学习者掌握 Java 应用在生产环境中的性能分析与优化能力。

19

2026.01.20

热门下载

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

精品课程

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

共14课时 | 0.8万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 2.9万人学习

CSS教程
CSS教程

共754课时 | 21.5万人学习

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

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