Rails 应用程序(狂欢) - 突然的“未捕获的类型错误”
Rails App (Spree) - Sudden "Uncaught Type Error"
我在我的Rails应用程序上运行了Spree Commerce的全新3.0版本安装。我使用以下方法将光滑滑块(光滑.js)添加到我的安装中:
<script></script>
在底部调用光滑滑块 这一切都很顺利,我什至设置了一些光滑的自定义.scss样式。所以我提交更改,关闭 Codekit,然后移动位置。再次打开我的Macbook,突然它抛出了一个爆炸的Uncatch TypeError:undefined不是一个函数。它被称为$(".slider-for").slick({
...
我一直在研究这个东西,我说不出发生了什么变化,也不知道为什么它没有加载。Slick在资源中,jQuery被加载,文件路径和元素都被适当地命名。这让我发疯,我不知道该怎么办。
相关文件:
主页设置
<div class="slider-for">
<% @products.each do |product| %>
<div>
<div class="product-image">
<%= link_to product_image(product), product %>
</div>
<div class="product-info">
<h2 class="product-title"><%= product.name %></h2>
<div class="product-description">
<%= product.description.to_s.html_safe %>
</div>
<div class="product-link">
<div class="product-price">
<%= product.display_price %>
</div>
<div class="product-more">
<%= link_to "Read More", product, class: "more-link" %>
</div>
</div>
</div>
</div>
<% end %>
</div>
<div class="slider-nav">
<% @products.each do |product| %>
<div>
<div class="product-image">
<%= product_image(product) %>
</div>
<h4 class="product-title"><%= product.name %></h4>
</div>
<% end %>
</div>
<script type="text/javascript">
$(document).ready(function(){
$(".slider-for").slick({
slidesToShow: 1,
slidesToScroll: 1,
arrows: false,
fade: true,
asNavFor: '.slider-nav'
});
$(".slider-nav").slick({
slidesToShow: 3,
slidesToScroll: 1,
asNavFor: '.slider-for',
dots: true,
centerMode: true,
focusOnSelect: true
});
});
</script>
头部部分:
<head data-hook="inside_head">
<meta charset="utf-8">
<title>Grand on Oak Boutique Store - Grand on Oak</title>
<meta content="text/html; charset=UTF-8" http-equiv="Content-Type">
<meta content="width=device-width, initial-scale=1.0, maximum-scale=1" name="viewport">
<meta name="keywords" content="boutique, boutique shop, clothing, clothing store">
<meta name="description" content="High-end shopping in Conway, Arkansas">
<link href="http://grandonoak.com/" rel="canonical">
<link rel="shortcut icon" type="image/x-icon" href="/assets/favicon-69231eed30cd5a922a19b067ccf8b243.ico">
<link rel="stylesheet" media="screen" href="/assets/spree/frontend/frontend_bootstrap-f5a4d0dbd069cabee02f14c2de1040d5.css?body=1">
<link rel="stylesheet" media="screen" href="/assets/spree/frontend-c946bacb82835ce1f9a9de94acfa7948.css?body=1">
<link rel="stylesheet" media="screen" href="/assets/spree/frontend/_variables-75e303a624880e205110a476763b276e.css?body=1">
<link rel="stylesheet" media="screen" href="/assets/spree/frontend/all-a523e282aabcd1ab0ec90f62c8f67344.css?body=1">
<meta name="csrf-param" content="authenticity_token">
<meta name="csrf-token" content="QD3LmjLGnTCtGkIX9NZw/W9UK5cP+LTB+aW5fQOErSCb/RgsfNOWvKDMNOJxbjXHkO5TS91cE54nKYDPeZJyow==">
<script src="/assets/jquery-87424c3c19e96d4fb033c10ebe21ec40.js?body=1"></script>
<script src="/assets/jquery_ujs-e27bd20a10d28155845a22d71ef94f2f.js?body=1"></script>
<script src="/assets/bootstrap/affix-86647d01ace516e05ddf78d2b6e85e20.js?body=1"></script>
<script src="/assets/bootstrap/alert-2a2796d28d7833f423ee421a3ad297bb.js?body=1"></script>
<script src="/assets/bootstrap/button-6b326d9b5034209f30109e77c264a190.js?body=1"></script>
<script src="/assets/bootstrap/carousel-31dbb9c732fc2da02b8d5a97d9ae0047.js?body=1"></script>
<script src="/assets/bootstrap/collapse-624b0c6035c65b5be6ae581d8dc4e196.js?body=1"></script>
<script src="/assets/bootstrap/dropdown-ce1bbc536745c41510513f7274f9897c.js?body=1"></script>
<script src="/assets/bootstrap/modal-77a0e72df31a788e4f6a3f28370eb69e.js?body=1"></script>
<script src="/assets/bootstrap/scrollspy-3892c697f57b7e7b9d5993044235a210.js?body=1"></script>
<script src="/assets/bootstrap/tab-6f45b70c6440bd0222c171dd7a926b5d.js?body=1"></script>
<script src="/assets/bootstrap/transition-264673896da1e31c3b865db964cd6592.js?body=1"></script>
<script src="/assets/bootstrap/tooltip-718496fb53635605964fb77613425c8d.js?body=1"></script>
<script src="/assets/bootstrap/popover-3dcfaa462d273d183ef52064ce120a5b.js?body=1"></script>
<script src="/assets/bootstrap-sprockets-830839b3b00123a30d090955aa74da5c.js?body=1"></script>
<script src="/assets/jquery.validate/jquery.validate.min-2d81074928b8de12627110241d1e7b82.js?body=1"></script>
<script src="/assets/jsuri-b9ca271e978b987b894cb0a92de921d9.js?body=1"></script>
<script src="/assets/spree-8ac8776671ec803cc33e03272659d498.js?body=1"></script>
<script src="/assets/spree/frontend/cart-1590808ff9329c79b63acdc5a84bc498.js?body=1"></script>
<script src="/assets/jquery.payment-99cc3707e9b4c29e1d1be187415f6415.js?body=1"></script>
<script src="/assets/spree/frontend/checkout-82e3443fe70333ace69246f9b31b9507.js?body=1"></script>
<script src="/assets/spree/frontend/checkout/address-616b9ad86f44c5fa74398e99accc9eee.js?body=1"></script>
<script src="/assets/spree/frontend/checkout/payment-4df84c09e7418b7aa6394f472f10fec9.js?body=1"></script>
<script src="/assets/spree/frontend/product-09bee3d334f4f5507d01406128c60330.js?body=1"></script>
<script src="/assets/spree/frontend-54fe02bb1f643864d4c75b951a66652e.js?body=1"></script>
<script src="/assets/spree/frontend/slick-6fd6b8e406e07fa296d234cc3a4b2a72.js?body=1"></script>
<script src="/assets/spree/frontend/all-5a6ef0f53abed7a46fdc4793b7e2a630.js?body=1"></script>
<!--[if lt IE 9]>
<script src="//cdnjs.cloudflare.com/ajax/libs/html5shiv/3.6/html5shiv.min.js"></script>
<![endif]-->
<link rel="next" href="/?page=2">
</head>
所有光滑滑块文件都与 Git master 并发。尝试过变体,但目前在适当的根文件夹中有 slick.js、slick.scss、slick-theme.scss。
解决了!因为我在初始安装Rails后使用Heroku进行部署,所以我有一堆预编译的资产显然导致了问题。
如果jQuery无缘无故地表现得很傻,只需删除公共/资产,您就可以开始了。或者,我认为您也可以重新预编译,这样可以解决问题。
希望这对其他人有所帮助!我敢肯定,我犯了菜鸟的错误,但我肯定因此落后了一天。
相关文章:
- 为什么会出现错误;未捕获的类型错误:undefined不是函数;
- 同样,同样的错误'ahorcado.js:26未捕获类型错误:无法读取属性'beginPath'
- 未捕获的类型错误:无法读取属性'删除'的未定义
- 未捕获的类型错误:无法读取属性'name'即使它存在,也无法定义
- 看到“;未捕获的类型错误:无法读取属性'weight'未定义的“;尽管按照字面上的指示
- Soundcloud api"未捕获的类型错误:无法读取属性'uri'“未定义”;
- 未捕获的类型错误:无法读取属性'addEventListener'的null chrome扩展名
- 如何解决这种情况下的非法调用类型错误
- 未捕获的类型错误:$(..).dataTable不是函数
- 未捕获的类型错误:无法读取属性'状态'在react中为null
- 未捕获的类型错误:topFrame.window.changeSelectedBarStyle不是函数,原因是什么
- 类型错误:url未定义extjs 4正在填充组合框
- 未捕获的类型错误:无法读取属性'中止'的未定义
- 类型错误'未定义'不是对象(正在评估'navigator.connection.type'
- 未捕获的类型错误:无法设置属性'innerHTML'如果为null,则将脚本移动到正文不会;不起作用
- 未捕获的类型错误:undefined不是函数$
- 输入类型文件的未捕获类型错误
- 未捕获的类型错误:无法设置属性'背景'的未定义
- "未捕获类型错误/丢弃意外“;因为一句台词而出现?(HTML w/<脚本>)
- Javascript未捕获类型错误:无法读取属性'0'的未定义