我正在尝试在 Rails 4 中制作一个应用程序。
我在挣扎。我正在尝试合并一个 Bootstrap 主题,但我遇到了 vendor javascript 和其余代码的问题。
我认为问题可能与在我的 application.js 中使用 jQuery 然后使用以“$”符号开头的 vendor .js 文件有关:
$.circleProgress = {
我刚读到:https://learn.jquery.com/using-jquery-core/avoid-conflicts-other-libraries/
我的问题是我不知道如何进行更改以确保代码安全。
我是否需要对 vendor 文件中的每个“$”进行搜索,或者我如何在 jQuery 上放置一个安全的包装器——尤其是它通过 gem 合并的地方。
有没有人遇到过这些问题并找到了解决方案?我需要一些帮助。
应用程序.js
//= require jquery
//= require bootstrap-sprockets
//= require jquery_ujs
//= require html.sortable
//= require disqus_rails
//= require moment
//= require bootstrap-datetimepicker
//= require pickers
//= require main
//= require hammer.min
//= require jquery.animate-enhanced.min
//= require jquery.countTo
//= require jquery.easing.1.3
//= require jquery.fitvids
//= require jquery.magnific-popup.min
//= require jquery.parallax-1.1.3
//= require jquery.properload
//= require jquery.shuffle.modernizr.min
//= require jquery.sudoSlider.min
//= require jquery.superslides.min
//= require masonry.pkgd.min
//= require rotaterator
//= require smoothscrolljs
//= require waypoints.min
//= require wow.min
//= require gmaps/google
//= require chosen-jquery
//= require cocoon
//= require imagesloaded.pkgd.min
//= require isotope.pkgd.min
//= require jquery.counterup.min
//= require jquery.pjax
//= require custom.js
//= require slider
//= require underscore
//= require dependent-fields
//= require_tree .
//= require bootstrap-slider
$(document).ready(function() {
DependentFields.bind()
});
相关问题:Rails 4 - incorporating vendor assets
观察
我注意到控制台错误日志显示我的 app/assets/javascripts 文件夹中的 .js 文件存在问题。
它们是该文件夹中唯一的其他文件(除了 application.js)。我的 application.js 有“require_tree”,因此它们将被编译。但我认为这些文件中的某些内容可能与(可能)在 application.js 中包含 jQuery 相冲突?
日志显示:
Uncaught SyntaxError: Identifier 'findGoodContent' has already been declared
circle-progress.self-f67ec54c54a06da27d11cda862036a058792eadc8ef982df2e7c0a1682536c31.js:9 Uncaught TypeError: Cannot set property 'circleProgress' of undefined
conversations.self-832ece2867c1701a5202459ab73ecd6432da2a6c833d8822d37025845a0aefcc.js:10 Uncaught TypeError: $ is not a function
organisations.self-6547f734e3a69b76176dfe5bb194e428c0bc560ad3fb69811dce9c7f8ccb9f4d.js:2 Uncaught TypeError: $ is not a function
http://localhost:3000/assets/%3C%=%20asset_path('random.jpg')%20%%3E Failed to load resource: the server responded with a status of 400 (Bad Request)
http://localhost:3000/profiles/assets/images/grayscale.svg#greyscale Failed to load resource: the server responded with a status of 404 (Not Found)
http://localhost:3000/assets/vendor/assets/fonts/Simple-Line-Icons.woff Failed to load resource: the server responded with a status of 404 (Not Found)
http://localhost:3000/profiles/assets/custom/images/preloader.gif Failed to load resource: the server responded with a status of 404 (Not Found)
chrome-extension://mkjojgglmmcghgaiknnpgjgldgaocjfd/content/contentScripts/kwift.CHROME.min.js:1384 Uncaught SyntaxError: Identifier 'findGoodContent' has already been declared
http://localhost:3000/assets/flaticon.woff Failed to load resource: the server responded with a status of 404 (Not Found)
http://localhost:3000/assets/vendor/assets/fonts/Simple-Line-Icons.ttf Failed to load resource: the server responded with a status of 404 (Not Found)
http://localhost:3000/assets/flaticon.ttf Failed to load resource: the server responded with a status of 404 (Not Found)
main.self-5888479bd3eb03114ce5776dd32cfadf84f1d3a4335043513f8b1606d3ab5f4a.js:316 Uncaught TypeError: dp(...).multipleFilterMasonry is not a function
每个被识别为错误的 js 文件夹都保存为 app/assets/javascripts 中的 .js 文件。
我是否需要使用不同的文件名 (.js.erb/js.coffee)?使这项工作。或者,我是否需要在这些文件的内容周围放置脚本标签?
例如,第一个文件打开:
$.circleProgress = {
// Default options (you may override them)
defaults: {
/**
* This is the only required option. It should be from 0.0 to 1.0
* @type {float}
*/
value: 0,
更新
我认为我的部分问题与保存在 app/assets/javascripts 中的扩展名为“.js”的文件有关。它们中的每一个都在控制台错误列表中显示为:
kwift.CHROME.min.js:1271Uncaught SyntaxError: Identifier 'findGoodContent' has already been declared
circle-progress.self-f67ec54….js?body=1:9 Uncaught TypeError: Cannot set property 'circleProgress' of undefined(anonymous function) @ circle-progress.self-f67ec54….js?body=1:9
conversations.self-832ece2….js?body=1:10 Uncaught TypeError: $ is not a function(anonymous function) @ conversations.self-832ece2….js?body=1:10
organisations.self-6547f73….js?body=1:2 Uncaught TypeError: $ is not a function(anonymous function) @ organisations.self-6547f73….js?body=1:2(anonymous function) @ organisations.self-6547f73….js?body=1:6
projects.self-9c019ba….js?body=1:1 Uncaught TypeError: $ is not a function(anonymous function) @ projects.self-9c019ba….js?body=1:1
main.self-5888479….js?body=1:316 Uncaught TypeError: dp(...).multipleFilterMasonry is not a functionwindow.onload @ main.self-5888479….js?body=1:316
kwift.CHROME.min.js:1271 Uncaught SyntaxError: Identifier 'findGoodContent' has already been declared
最佳答案
听起来您有很多清理工作要做。这是您的第一个 Rails 应用程序吗?如果是这样,我很好奇为什么您已经有这么多 JS 文件。我会把你的 list 缩减到几个,解决剩下的问题,然后慢慢开始添加东西并解决问题。那将是我的总体策略。对于每个错误,慢慢来并仔细检查您是否真正了解原因,然后再在这里和那里削减希望修复。
以下是针对我看到的特定错误的一些提示:
此行将包括所有 .js app/assets/javascripts 中的文件:
//= require_tree .
问题是您已经在上面一一包含了它们。所以他们被包括在内两次。这就是为什么您会收到类似 'findGoodContent' has already been declared 的警告.我知道它很好用 require_tree (虽然我不喜欢它),所以如果你想保留它,请考虑将所有第 3 方 JS 文件移出 app/assets/javascripts并进入 vendor/assets/javascripts .你仍然可以 require他们在你的application.js , 但它们不会被 require_tree 重复.
类似 grayscale.svg 的 404 错误和 flaticon.woff和其他图像/字体 Assets 是因为您在 app/assets 中没有这些文件(或 vendor/assets )。或者如果你这样做,你应该确保你的 JS/CSS 文件和 View 文件使用 <%= asset_path "grayscale.svg" %> 引用它们这样当 Rails 破坏它们的路径时,您仍然可以从正确的位置加载它们。了解 image_url and friends并确保您了解它们的工作原理。默认情况下,Asset Pipeline 在开发中提供未损坏的名称,在生产中提供损坏的名称,因此在您将其全部上线之前,事情可能会正常进行!
此外,如果您包含 <%= foo %> CSS 文件或 JS 文件中的标签,则需要添加 .erb该文件的扩展名,以便 Rails 知道要处理这些标签。这就是为什么您在尝试加载时遇到 404 错误:
http://localhost:3000/assets/%3C%=%20asset_path('random.jpg')%20%%3E
在你的一个文件中,可能是一个 CSS 文件,你正在做这样的事情:
background-image: url("<%= asset_path('random.jpg') %>");
但是文件需要一个 .erb扩展名:blah.css.erb或 blah.scss.erb或其他。
类似$ is not a function 的错误意味着这些文件依赖于 jQuery,但是 jQuery $对象未定义。如果您使用 noConflict ,正如有人在评论中建议的那样,你应该停下来,因为你确实想要$成为 jQuery 对象。
祝你好运!如果您感到不知所措,我真的会从删除尽可能多的 JS require 开始。尽可能行,并一次解决一个错误。
此外,我会重新订购 require行,以便依赖项位于顶部(例如 jquery),而依赖它们的东西位于较低位置。
还有一件事,不是真正的错误:我会避免将已经缩小的文件(如 hammer.min.js )放入您的存储库。 Asset Pipeline 知道如何缩小。所以 checkin 未压缩版本,这样如果你必须阅读源代码,你可以。
关于javascript - Rails 4 jQuery 与 javascript 冲突,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36734854/
很好奇,就使用rubyonrails自动化单元测试而言,你们正在做什么?您是否创建了一个脚本来在cron中运行rake作业并将结果邮寄给您?git中的预提交Hook?只是手动调用?我完全理解测试,但想知道在错误发生之前捕获错误的最佳实践是什么。让我们理所当然地认为测试本身是完美无缺的,并且可以正常工作。下一步是什么以确保他们在正确的时间将可能有害的结果传达给您? 最佳答案 不确定您到底想听什么,但是有几个级别的自动代码库控制:在处理某项功能时,您可以使用类似autotest的内容获得关于哪些有效,哪些无效的即时反馈。要确保您的提
这似乎应该有一个直截了当的答案,但在Google上花了很多时间,所以我找不到它。这可能是缺少正确关键字的情况。在我的RoR应用程序中,我有几个模型共享一种特定类型的字符串属性,该属性具有特殊验证和其他功能。我能想到的最接近的类似示例是表示URL的字符串。这会导致模型中出现大量重复(甚至单元测试中会出现更多重复),但我不确定如何让它更DRY。我能想到几个可能的方向...按照“validates_url_format_of”插件,但这只会让验证干给这个特殊的字符串它自己的模型,但这看起来很像重溶液为这个特殊的字符串创建一个ruby类,但是我如何得到ActiveRecord关联这个类模型
我的目标是转换表单输入,例如“100兆字节”或“1GB”,并将其转换为我可以存储在数据库中的文件大小(以千字节为单位)。目前,我有这个:defquota_convert@regex=/([0-9]+)(.*)s/@sizes=%w{kilobytemegabytegigabyte}m=self.quota.match(@regex)if@sizes.include?m[2]eval("self.quota=#{m[1]}.#{m[2]}")endend这有效,但前提是输入是倍数(“gigabytes”,而不是“gigabyte”)并且由于使用了eval看起来疯狂不安全。所以,功能正常,
作为我的Rails应用程序的一部分,我编写了一个小导入程序,它从我们的LDAP系统中吸取数据并将其塞入一个用户表中。不幸的是,与LDAP相关的代码在遍历我们的32K用户时泄漏了大量内存,我一直无法弄清楚如何解决这个问题。这个问题似乎在某种程度上与LDAP库有关,因为当我删除对LDAP内容的调用时,内存使用情况会很好地稳定下来。此外,不断增加的对象是Net::BER::BerIdentifiedString和Net::BER::BerIdentifiedArray,它们都是LDAP库的一部分。当我运行导入时,内存使用量最终达到超过1GB的峰值。如果问题存在,我需要找到一些方法来更正我的代
在我的Rails(2.3,Ruby1.8.7)应用程序中,我需要将字符串截断到一定长度。该字符串是unicode,在控制台中运行测试时,例如'א'.length,我意识到返回了双倍长度。我想要一个与编码无关的长度,以便对unicode字符串或latin1编码字符串进行相同的截断。我已经了解了Ruby的大部分unicode资料,但仍然有些一头雾水。应该如何解决这个问题? 最佳答案 Rails有一个返回多字节字符的mb_chars方法。试试unicode_string.mb_chars.slice(0,50)
如何正确创建Rails迁移,以便将表更改为MySQL中的MyISAM?目前是InnoDB。运行原始执行语句会更改表,但它不会更新db/schema.rb,因此当在测试环境中重新创建表时,它会返回到InnoDB并且我的全文搜索失败。我如何着手更改/添加迁移,以便将现有表修改为MyISAM并更新schema.rb,以便我的数据库和相应的测试数据库得到相应更新? 最佳答案 我没有找到执行此操作的好方法。您可以像有人建议的那样更改您的schema.rb,然后运行:rakedb:schema:load,但是,这将覆盖您的数据。我的做法是(假设
我正在尝试测试是否存在表单。我是Rails新手。我的new.html.erb_spec.rb文件的内容是:require'spec_helper'describe"messages/new.html.erb"doit"shouldrendertheform"dorender'/messages/new.html.erb'reponse.shouldhave_form_putting_to(@message)with_submit_buttonendendView本身,new.html.erb,有代码:当我运行rspec时,它失败了:1)messages/new.html.erbshou
我在从html页面生成PDF时遇到问题。我正在使用PDFkit。在安装它的过程中,我注意到我需要wkhtmltopdf。所以我也安装了它。我做了PDFkit的文档所说的一切......现在我在尝试加载PDF时遇到了这个错误。这里是错误:commandfailed:"/usr/local/bin/wkhtmltopdf""--margin-right""0.75in""--page-size""Letter""--margin-top""0.75in""--margin-bottom""0.75in""--encoding""UTF-8""--margin-left""0.75in""-
Rails2.3可以选择随时使用RouteSet#add_configuration_file添加更多路由。是否可以在Rails3项目中做同样的事情? 最佳答案 在config/application.rb中:config.paths.config.routes在Rails3.2(也可能是Rails3.1)中,使用:config.paths["config/routes"] 关于ruby-on-rails-Rails3中的多个路由文件,我们在StackOverflow上找到一个类似的问题
给定这段代码defcreate@upgrades=User.update_all(["role=?","upgraded"],:id=>params[:upgrade])redirect_toadmin_upgrades_path,:notice=>"Successfullyupgradeduser."end我如何在该操作中实际验证它们是否已保存或未重定向到适当的页面和消息? 最佳答案 在Rails3中,update_all不返回任何有意义的信息,除了已更新的记录数(这可能取决于您的DBMS是否返回该信息)。http://ar.ru