npm 包 rails-assets-source-maps 使用教程

在前端开发过程中,我们经常需要调试 JavaScript 的代码。然而,当代码被打包成一个文件后,调试变得非常困难。这时,source maps 技术就出现了。

source maps 是一种映射技术,它能够将打包后的代码映射回源代码,从而方便我们调试。在本文中,我们将介绍如何使用 npm 包 rails-assets-source-maps,来实现在 Rails 应用中使用 source maps。

安装和配置

首先,我们需要在 Rails 应用中添加 rails-assets-source-maps 依赖。在 Gemfile 中添加:

------ ----------------------
--- --------------------------- --- ------

然后,运行 bundle 安装新的 Gem:

- ------ -------

之后,我们需要在 application.js 和 application.css 文件中启用 source maps。在 application.js 中添加:

--- ------- ------------------------

在 application.css 中添加:

------- ---------------------------

最后,我们还需要为 Rails 配置 source maps。在 config/application.rb 中添加:

----------------------- -- -----
  ------------------------ ------------------ ------------------------- ----------------------------------------------
---

到此,我们的安装和配置工作就完成了。接下来,我们将演示如何使用 rails-assets-source-maps。

使用示例

我们需要一个简单的 Rails 应用,和一个包含单个 JavaScript 文件的 Rails Engine。如图所示:

--- ---
-   --- ------
-       --- -----------
-           --- --------------
--- -------
    --- ---------
        --- ---
            --- ------
                --- -----------
                    --- ------------

application.js 包含如下代码:

--- ------- ------
--- ------- ----------
--- ------- ----------
--- ------------ -
--- ------- ---------

my_engine.js 包含如下代码:

---------- -- -
  ------------------- -- ---------
---

我们需要使用 source maps 来调试 my_engine.js。

首先,我们需要在浏览器中打开调试工具(例如 Chrome),并在控制台中启用 source maps。

然后,我们访问我们的应用并在控制台中执行如下代码:

-- -- ------ ----
------------------------------
  -------------------- ----------------------------
--

-- ---- ------ ----
----------------------------------------
  -------------- -- ----------------
  ---------- -- -
    ----- -------- - --- ------------------------
    ------------------------------------------ ----- -- ------- -- ----
  ---

上述代码中,我们首先启用了 source maps,并将 source maps 文件的路径配置为 /source-maps/mappings.wasm。然后,我们异步加载了 application.js.map 文件,并使用 SourceMapConsumer 类解析了这个文件。最后,我们使用 originalPositionFor 方法来获取 my_engine.js 中某行代码的源代码位置。

这里有一个小技巧,如果我们想要简化这个过程,可以在控制台中输入:

-- -- ------ ----
------------------------------
  -------------------- ----------------------------
--

-------------------------------------------------------------------------- -------- -- -
  ----- -------- - --- --------------------------
  ------------------------------------------ ----- -- ------- -- ----
---

这样,我们就可以自动获取 my_engine.js 文件的 source maps,并直接使用 SourceMapConsumer 类解析源代码位置了。

总结

在本文中,我们介绍了如何使用 npm 包 rails-assets-source-maps,在 Rails 应用中使用 source maps 技术。我们讨论了安装和配置、使用示例等主题,并提供了详细的代码示例。希望这篇文章能够对您有所帮助,让您在前端开发中更加轻松地调试代码。

来源:JavaScript中文网 ,转载请联系管理员! 本文地址:https://www.javascriptcn.com/post/74148


猜你喜欢

  • 使用 workshopper-adventure-test 包测试您的 Node.js 应用程序

    在开发 Node.js 应用程序时,测试是一件非常重要的事情。在 Node.js 中实现测试非常容易,这要归功于 Node.js 社区常用的测试框架 -- Mocha,以及 Chai 断言库。

    5 年前
  • npm 包 learnyounode 使用教程

    前言 作为前端开发人员,很多时候需要写一些 Node.js 的代码,比如搭建后端服务器,编写一些脚本等等。而 learnyounode 这个 npm 包就是为了帮助你入门 Node.js 编程而生的。

    5 年前
  • npm 包 statsd-librato-backend 使用教程

    背景介绍 在前端开发中,我们经常需要统计和监控应用程序的性能指标和报错信息。为了收集这些数据,我们通常会使用 metrics 后端服务比如 Librato、Graphite、InfluxDB 等等。

    5 年前
  • npm 包 npm-stats 使用教程

    前言 npm 是前端开发中用得非常频繁的包管理工具,很多开发者都会使用 npm 安装和管理第三方模块。但是,除了使用 npm 进行安装和卸载之外,我们还可以使用 npm-stats 这个包来了解 np...

    5 年前
  • npm 包 pkgs 使用教程

    Npm 包管理器是 JavaScript 生态系统中最常用的包管理器。与其他包管理器不同,它具有大量的开源包,可以快速地为我们的前端项目提供各种功能和工具。其中 pkgs 是一个值得尝试的工具,本文将...

    5 年前
  • npm包backfill使用教程

    什么是backfill backfill是一个npm包,它的作用是将一个项目的依赖项拆散,只安装其中未安装的依赖项。通过这种方式,能够大大减小项目的体积,并且在模块打包时可以更快的打包。

    5 年前
  • npm 包 npm-collection-explicit-installs 使用教程

    在进行前端开发时,我们常常需要引入许多依赖包,这些依赖包通过 npm 安装非常方便。但是,当我们使用一些比较冷门的包时可能会遇到一些问题,例如版本兼容性问题、包冲突等等。

    5 年前
  • npm 包 socketio-jwt 使用教程

    前言 在现代 web 应用程序中,实时通信变得越来越重要。Socket.IO 是一个用于实现实时通信的库,而 JWT(JSON Web Token) 则是一种安全传输信息的方式。

    5 年前
  • npm 包 pi-dashboard 使用教程

    简介 pi-dashboard 是一个用于 Web 界面中展示 Raspberry Pi 硬件信息和使用情况的 npm 包。它提供了一个简洁美观的仪表盘,包含 CPU、内存、硬盘和网络等多个方面的指标...

    5 年前
  • npm 包 default-pager 使用教程

    前言 在前端开发中,分页功能是一个经典的需求,而实现分页功能需要编写大量的代码,增加了开发工作量,降低了开发效率。为了解决这个问题,有很多分页插件可以使用,其中 default-pager 是一个非常...

    5 年前
  • npm 包 highlight-redux 使用教程

    在 Web 开发中,语法高亮对于展示代码来说是非常重要的。而高端的 Web 应用程序很多都需要在前端使用某些框架来实现状态管理和数据流动。在此情况下,有一个叫做 highlight-redux 的 n...

    5 年前
  • npm 包 ultramarked 使用教程

    ultramarked 是一个轻量级、快速且易于使用的 Markdown 解析器和渲染器,适用于前端开发工作。它支持常见的 Markdown 语法,同时还扩展了一些非常有用的功能,例如 hljs(代码...

    5 年前
  • npm 包 hget 使用教程

    介绍 hget 是一个可以在 Node.js 环境下使用的 npm 包,它提供了一种很方便的方式来获取 HTML 页面中的指定元素或属性的值。它的作用和 jQuery 中的 $(selector).a...

    5 年前
  • npm 包 assignment 使用教程

    前言 在前端开发中,我们经常会用到一些第三方库和包来提高开发效率,其中 npm 是一个十分强大的包管理器。npm 包能够将许多常用的、复杂的功能打包成一个模块,供其他开发者使用,从而简化开发流程。

    5 年前
  • npm 包 formulario 使用教程

    前言 在前端开发中,时常需要处理表单的数据,并将其发送至后端进行处理。而 formulario 是一个能够帮助前端快速生成表单、收集表单数据、进行表单验证以及发送请求等功能的 npm 包。

    5 年前
  • npm 包 queso 使用教程

    前言 在前端开发中,常常会使用一些工具库和框架来辅助开发,npm 是一个非常常用的工具库,而 queso 是一款适用于 JavaScript 和 TypeScript 的业务型工具库,为前端开发者提供...

    5 年前
  • npm 包 formium 使用教程

    前言 在前端开发中,很多时候我们需要创建表单以便用于用户输入数据、提交数据等。而一个好用的表单组件对于提高开发效率和用户体验都有很大作用。本文将介绍一个 npm 包 formium,它是一个强大的表单...

    5 年前
  • npm 包 Sektor 使用教程

    Sektor 是一个轻量级的 JavaScript 库,用于实现 SVG 路径上的动态控制点。它是一个 npm 包,可以轻松地集成到你的前端应用程序中。 本文将介绍如何使用 Sektor 库来创建可交...

    5 年前
  • npm 包 poser 使用教程

    在前端开发中,我们经常使用各种 npm 包来简化我们的工作流程。其中,poser 是一个非常强大的 npm 包,它可以帮助我们生成各种类型的占位符,从而简化我们的开发过程。

    5 年前
  • npm 包 dominus 使用教程

    在前端开发中,我们经常需要进行 DOM 操作,比如改变元素的样式、位置,获取元素的属性等等。为了方便地进行这些操作,我们可以使用 npm 包 dominus。 什么是 dominus dominus ...

    5 年前

相关推荐

    暂无文章