jQuery 2.2.4 和 3.6.0 版本重叠错误
我发现了我想集成到网站(我购买的模板)的代码,该代码仍在开发中。问题是该网站正在jQuery 3.6.0上运行,我想集成的此代码使用jQuery 2.2.4。
现在,当我将代码添加到网站上时,它可以正常运行,但另一方面,其他网站功能停止运行。当我检查控制台时,我会看到object.firewith
和function.dready
之类的错误,我对JavaScript不好。
您能帮我在最新的jQuery 3.6.0而不是2.2.4上运行此代码吗?
谢谢您的任何帮助。
$(window).on('load', function() {
// Please run it with window.onload, not with document.ready
initSmoothScrolling('.carouselblocks', 'smoothscroll');
});
function initSmoothScrolling(carouselblocks, carouselanimation) {
/*
* @param {String} container Class or ID of the animation container
* @param {String} animation Name of the animation, e.g. smoothscroll
*/
var sliderWidth = 0;
var animationWidth = 0;
var sliderHeight = $('>div>div:first-of-type', carouselblocks).outerHeight(false);
$('>div>div', carouselblocks).each(function() {
animationWidth += $(this).outerWidth(false);
});
// detect number of visible slides
var slidesVisible = $(carouselblocks).width() / $('>div>div:first-of-type', carouselblocks).outerWidth(true);
slidesVisible = Math.ceil(slidesVisible);
// count slides to determine animation speed
var slidesNumber = $('>div>div', carouselblocks).length;
var speed = slidesNumber * 2;
// append the tail
$('>div>div', carouselblocks).slice(0, slidesVisible).clone().appendTo($('>div', carouselblocks));
// Detect the slider width with appended tail
$('>div>div', carouselblocks).each(function() {
sliderWidth += $(this).outerWidth(false);
});
// set slider dimensions
$('>div', carouselblocks).css({
'width': sliderWidth,
'height': sliderHeight
});
// Insert styles to html
$("<style type='text/css'>@keyframes " + carouselanimation + " { 0% { margin-left: 0px; } 100% { margin-left: -" + animationWidth + "px; } } " + $('>div>div:first-of-type', carouselblocks).selector + " { -webkit-animation: " + carouselanimation + " " + speed + "s linear infinite; -moz-animation: " + carouselanimation + " " + speed + "s linear infinite; -ms-animation: " + carouselanimation + " " + speed + "s linear infinite; -o-animation: " + carouselanimation + " " + speed + "s linear infinite; animation: " + carouselanimation + " " + speed + "s linear infinite; }</style>").appendTo("head");
// restart the animation (e.g. for safari & ie)
var cl = $(carouselblocks).attr("class");
$(carouselblocks).removeClass(cl).animate({
'nothing': null
}, 1, function() {
$(this).addClass(cl);
});
}
html,
body {
margin: 0;
padding: 0;
}
.carouselblocks {
overflow: hidden;
width: 100vw;
margin: 50px auto;
}
.carouselanimation {
width: auto;
height: 100px;
font-size: 0px;
}
.carouselanimation div {
display: inline-block;
width: auto;
float: none;
padding: 0 10px;
}
<body>
<!-- partial:index.partial.html -->
<div class="carouselblocks">
<div class="carouselanimation">
<div><img src="http://fpoimg.com/200x200?text=First"></div>
<div><img src="http://fpoimg.com/200x200?text=Second"></div>
<div><img src="http://fpoimg.com/200x200?text=Third"></div>
<div><img src="http://fpoimg.com/200x200"></div>
<div><img src="http://fpoimg.com/200x200"></div>
<div><img src="http://fpoimg.com/200x200"></div>
<!-- cut -->
</div>
</div>
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.6.0/jquery.min.js"></script>
<!-- script src="./script.js"></script -->
</body>
I found this piece of code that I want to integrate to a website (a template that I purchased) which is still under development. The issue is that the website is running on jQuery 3.6.0, and this code that I want to integrate is using jQuery 2.2.4.
Now, when I add the code to the website, it works fine, but in the other hand, other website functions stops running. and when I check the console I see errors like Object.fireWith
and Function.ready
and I'm not good with JavaScript.
Can you help me make this piece of code run on the latest jQuery 3.6.0 instead of 2.2.4?
Thank you for any help.
$(window).on('load', function() {
// Please run it with window.onload, not with document.ready
initSmoothScrolling('.carouselblocks', 'smoothscroll');
});
function initSmoothScrolling(carouselblocks, carouselanimation) {
/*
* @param {String} container Class or ID of the animation container
* @param {String} animation Name of the animation, e.g. smoothscroll
*/
var sliderWidth = 0;
var animationWidth = 0;
var sliderHeight = $('>div>div:first-of-type', carouselblocks).outerHeight(false);
$('>div>div', carouselblocks).each(function() {
animationWidth += $(this).outerWidth(false);
});
// detect number of visible slides
var slidesVisible = $(carouselblocks).width() / $('>div>div:first-of-type', carouselblocks).outerWidth(true);
slidesVisible = Math.ceil(slidesVisible);
// count slides to determine animation speed
var slidesNumber = $('>div>div', carouselblocks).length;
var speed = slidesNumber * 2;
// append the tail
$('>div>div', carouselblocks).slice(0, slidesVisible).clone().appendTo($('>div', carouselblocks));
// Detect the slider width with appended tail
$('>div>div', carouselblocks).each(function() {
sliderWidth += $(this).outerWidth(false);
});
// set slider dimensions
$('>div', carouselblocks).css({
'width': sliderWidth,
'height': sliderHeight
});
// Insert styles to html
$("<style type='text/css'>@keyframes " + carouselanimation + " { 0% { margin-left: 0px; } 100% { margin-left: -" + animationWidth + "px; } } " + $('>div>div:first-of-type', carouselblocks).selector + " { -webkit-animation: " + carouselanimation + " " + speed + "s linear infinite; -moz-animation: " + carouselanimation + " " + speed + "s linear infinite; -ms-animation: " + carouselanimation + " " + speed + "s linear infinite; -o-animation: " + carouselanimation + " " + speed + "s linear infinite; animation: " + carouselanimation + " " + speed + "s linear infinite; }</style>").appendTo("head");
// restart the animation (e.g. for safari & ie)
var cl = $(carouselblocks).attr("class");
$(carouselblocks).removeClass(cl).animate({
'nothing': null
}, 1, function() {
$(this).addClass(cl);
});
}
html,
body {
margin: 0;
padding: 0;
}
.carouselblocks {
overflow: hidden;
width: 100vw;
margin: 50px auto;
}
.carouselanimation {
width: auto;
height: 100px;
font-size: 0px;
}
.carouselanimation div {
display: inline-block;
width: auto;
float: none;
padding: 0 10px;
}
<body>
<!-- partial:index.partial.html -->
<div class="carouselblocks">
<div class="carouselanimation">
<div><img src="http://fpoimg.com/200x200?text=First"></div>
<div><img src="http://fpoimg.com/200x200?text=Second"></div>
<div><img src="http://fpoimg.com/200x200?text=Third"></div>
<div><img src="http://fpoimg.com/200x200"></div>
<div><img src="http://fpoimg.com/200x200"></div>
<div><img src="http://fpoimg.com/200x200"></div>
<!-- cut -->
</div>
</div>
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.6.0/jquery.min.js"></script>
<!-- script src="./script.js"></script -->
</body>
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
data:image/s3,"s3://crabby-images/d5906/d59060df4059a6cc364216c4d63ceec29ef7fe66" alt="扫码二维码加入Web技术交流群"
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论