From 481a3543c14ddde04c5e0b871feb6790c22d50d2 Mon Sep 17 00:00:00 2001 From: Adam Conrad Date: Mon, 17 Aug 2015 23:08:30 -0400 Subject: [PATCH] Some minor linting fixes and cleanup My team is using this plugin and I noticed a few places that needed to be cleaned up and optimized: 1. A bunch of inconsistency with the use of strict equality (`===`). Strict equality should always be used when you're not dealing with falsey objects (i.e. `null == undefined` is permitted, so therefore `obj == null` or `obj == undefined` is permissible) 2. There was a missing semicolon. Every other line ends with a semicolon, so that one needed one as well. 3. A minor for loop optimization would be to cache the length of the for loop inside of a variable in the first portion of the loop. This saves having to call length every single time.While this is optimized in modern browsers, given you support legacy browsers, this is a worthwhile optimization. --- jquery.sticky.js | 14 +++++++------- 1 file changed, 7 insertions(+), 7 deletions(-) diff --git a/jquery.sticky.js b/jquery.sticky.js index b82e195..56c0055 100644 --- a/jquery.sticky.js +++ b/jquery.sticky.js @@ -45,7 +45,7 @@ dwh = documentHeight - windowHeight, extra = (scrollTop > dwh) ? dwh - scrollTop : 0; - for (var i = 0; i < sticked.length; i++) { + for (var i = 0, l = sticked.length; i < l; i++) { var s = sticked[i], elementTop = s.stickyWrapper.offset().top, etse = elementTop - s.topSpacing - extra; @@ -74,7 +74,7 @@ } else { newTop = s.topSpacing; } - if (s.currentTop != newTop) { + if (s.currentTop !== newTop) { var newWidth; if (s.getWidthFrom) { newWidth = $(s.getWidthFrom).width() || null; @@ -114,11 +114,11 @@ resizer = function() { windowHeight = $window.height(); - for (var i = 0; i < sticked.length; i++) { + for (var i = 0, l = sticked.length; i < l; i++) { var s = sticked[i]; var newWidth = null; if (s.getWidthFrom) { - if (s.responsiveWidth === true) { + if (s.responsiveWidth) { newWidth = $(s.getWidthFrom).width(); } } else if(s.widthFromWrapper) { @@ -137,7 +137,7 @@ var stickyId = stickyElement.attr('id'); var stickyHeight = stickyElement.outerHeight(); - var wrapperId = stickyId ? stickyId + '-' + defaults.wrapperClassName : defaults.wrapperClassName + var wrapperId = stickyId ? stickyId + '-' + defaults.wrapperClassName : defaults.wrapperClassName; var wrapper = $('
') .attr('id', wrapperId) .addClass(o.wrapperClassName); @@ -150,7 +150,7 @@ stickyWrapper.css({width:stickyElement.outerWidth(),marginLeft:"auto",marginRight:"auto"}); } - if (stickyElement.css("float") == "right") { + if (stickyElement.css("float") === "right") { stickyElement.css({"float":"none"}).parent().css({"float":"right"}); } @@ -177,7 +177,7 @@ removeIdx = i; } } - if(removeIdx != -1) { + if(removeIdx !== -1) { unstickyElement.unwrap(); unstickyElement .css({