当前位置: 首页 > 编程笔记 >

Ruby on Rails中jquery_ujs组件拖慢速度的问题解决

轩辕天佑
2023-03-14
本文向大家介绍Ruby on Rails中jquery_ujs组件拖慢速度的问题解决,包括了Ruby on Rails中jquery_ujs组件拖慢速度的问题解决的使用技巧和注意事项,需要的朋友参考一下

jquery_ujs 对 rails 来说,是一个非常重要的组件,它包含在 rails 的默认组件之中。

jquery ujs 包含一些非常便捷的功能,比如确认对话框、触发 ajax、自动禁用表单提交按钮等,本文主要讨论的是触发 ajax 的功能。

通过添加简单的标签属性,jquery ujs 可以把一个普通的链接或者表单转换成 ajax 提交,而不需要写 JavaScript 代码。

<%= link_to '关闭项目', close_project_path(project), remote: true, method: :post %>

上面的代码会生成如下的代码

<a href="/projects/1/close" data-remote="true" data-method="post">关闭项目</a>

当用户点击后,它会触发一个指向地址 /projects/1/close,method 为 post 的 ajax 请求,而不是 get 的 普通请求,这样使得实现 ajax 调用变得非常便捷。

网速慢导致的问题
事情并不都是美好的,在网速比较慢的时候,jquery ujs 的这个实现会出问题,如果文档还没有加载完成,用户就点击了链接,页面会发起一个到链接地址的 GET 请求,页面会跳转,但指向该地址的 GET 请求可以并不存在,这样就会出错。

有用户有提过一个相关的 Issue,但是开发者并没有受理,然而网速慢是中国的国情,问题我们还是得处理,借助于 CSS3 的一些特性,这个问题其实也不难解决。

pointer-events
pointer-events: none;

The element is never the target of mouse events; however, mouse events may target its descendant elements if those descendants have pointer-events set to some other value. In these circumstances, mouse events will trigger event listeners on this parent element as appropriate on their way to/from the descendant during the event capture/bubble phases.

这个属性可以禁止元素的点击事件,因为一般 CSS 是先加载的,我们只要控制在页面加载完成之前给 jquery ujs 相关的元素应用 pointer-events: none; 样式,在页面加载完成后再去除该样式,就可以解决网速慢的情况下,页面没有加载完成时用户点击 rmote 链接导致的错误了。

解决方案
添加如下的全局样式,默认情况下含有 data-remote 和 data-method 属性的标签不可点击,除非 body 元素含有名为 ready 的 css class。

[data-remote], [data-method] {
 pointer-events: none;

 button, input[type=submit] {
  pointer-events: none;
 }
}

body.ready {
 [data-remote], [data-method] {
  pointer-events: auto;

  button, input[type=submit] {
   pointer-events: auto;
  }
 }
}

然后通过段简单的脚本让页面加载后给 body 元素添加 ready class

$(document).ready ->
 $('body').addClass('ready')

于是,问题轻松的就解决了。

 类似资料:
  • 现在有三台ES服务器,索引里大概有7000条数据,每条数据是内容放到txt中大概300kb以上,按某个查询条件查询的结果数量是4000多条数据。当size设置成9999的时候,需要查询30秒以上,这是为什么呢,有没有优化方案。

  • 我已经使用CMU sphinx 4编写了语音识别应用程序,并遵循了此链接中的详细信息。我对声学、词典和语言模型的定义如下 使用上述配置,20分钟的wav文件几乎需要20分钟来完成转录。因此,我尝试传递用户定义的config.xml.我没有找到配置管理器选项来传递用户定义的config.xml与当前版本的Sphinx4。然后,我通过扩展类(可能没用)编写了自己的识别器,并更改了config.xml的

  • 我从来没有用过红宝石,我想我应该试一试。安装似乎进行得很顺利(我想)。在我使用创建服务器后,麻烦就开始了,然后去设置路由,这样新项目就会出现,而不是红宝石欢迎屏幕。它产生的误差是 未初始化常量欢迎控制器 我在route controller中设置了路径,如下所示 我漏了一步吗?我正在使用installrails的说明在Windows7上安装rails。通用域名格式 这是请求的完整跟踪

  • 本文向大家介绍Eclipse安装ADT插件速度慢的解决方法,包括了Eclipse安装ADT插件速度慢的解决方法的使用技巧和注意事项,需要的朋友参考一下 本文讲述了Eclipse安装ADT插件速度慢的解决方法。分享给大家供大家参考,具体如下: 在天朝很多事情就不可避免的蛋疼,download.eclipse.org 访问巨慢,导致 ADT 安装过程也巨慢,有事运气好会快一点,但大部分时候就跟shit

  • 在使用disruptor时,可能会有一个(多个)消费者落后,并且由于这个缓慢的消费者,整个应用程序都会受到影响。 请记住,每个生产者(发布者)和消费者(EventProcessor)都在一个线程上运行,如何解决消费者速度慢的问题? 我们可以在单个消费者上使用多个线程吗?如果没有,有什么更好的选择?

  • 我遇到了java在SSL上使用时速度较慢的问题。解决方案是添加 现在,java.security文件已经包含 “/dev/urandom”与“/dev/./urandom”不同的原因和方式。为什么java不接受“/dev/urandom” 对于我正在运行的JVM,如何判断它们是否使用了正确的urandmon设备(vs random)