1

Good afternoon everyone, I've managed to write a script that calculates the width and height of an image and properly placed a string of text on the bottom right side of an image for usage with credits/captions.

I've managed to get it to generate, calculate and display perfectly in all browsers other than IE8. For some reason, it is blowing off the screen in IE8 and I can't seem to figure out why it is doing it and improve my JavaScript to possibly have conditional functions for calculations when using IE8.

Any advice?

http://jsfiddle.net/jodriscoll/u26vZ/

$(function ($) {
    // jQuery is passed as the first arg $
    $('.img-right img,.img-left img').bind('load', function () {
        var $img = $(this),
            imgHeight = $img.height(),
            imgWidth = $img.width();
        $img.siblings('p').width(imgWidth);
        $img.siblings('span').width(imgHeight);
        $img.siblings('.credit').css({
            left: imgWidth + 6,
            top: imgHeight - 10
        });
    }).each(function () {
        // we need to force the "load" event to fire if it was already complete:
        // technique taken from https://gist.github.com/268257
        if (this.complete || this.complete === undefined) {
            var src = this.src;
            // webkit hack from http://groups.google.com/group/jquery-dev/browse_thread/thread/eee6ab7b2da50e1f
            // data uri bypasses webkit log warning
            this.src = "";
            this.src = src;
        }
    });
});
OptimizedQuery
  • 1,262
  • 11
  • 21
Joey O
  • 315
  • 2
  • 17
  • you're overriding the `this.src` two times. Why that? – Roko C. Buljan Apr 22 '13 at 14:54
  • Do some debugging to see where the numbers are off and why. – Kevin B Apr 22 '13 at 14:55
  • @roXon = Read more on this approach here: http://groups.google.com/group/jquery-dev/browse_thread/thread/eee6ab7b2da50e1f – Joey O Apr 22 '13 at 15:03
  • @Kevin B = Not really sure how that answers anything or provides any instruction for guidance, but I will continue looking into it. – Joey O Apr 22 '13 at 15:03
  • Go through it line by line and figure out where the numbers start to differ. – Kevin B Apr 22 '13 at 15:04
  • Kevin B, sorry that isn't providing very much help to the issue. – Joey O Apr 22 '13 at 16:51
  • I've created a test page in the environment it's meant to live in below. Please use any form of debugging on this page http://www.massgeneral.org/museum/visit/testing-javascript.aspx. – Joey O Apr 22 '13 at 18:36

1 Answers1

1

Here's how I would go about doing it, and it's not as much work for the browser as far processing the code in your js script. That's a bit unnecessary for something like this.

I've changed the html so the image and vertical text is wrapped with a figure element, and the vertical text is a figcaption instead of a span too.

I changed the CSS so that the img-right divs are position relative, and inline-block, and the vertical text is absolute with right and bottom positions of 0 or whatever so that they are properly and all equally positioned correctly, this should work across browsers, but should it still be mis-aligned in IE, you can simply modify the right and bottom position values for IE specifically using the class in the html tag that specifies it's ie7 or 8 or whatever browser you may need to target.

The script which I did write and all that is necessary for how I went about this, simply sets the img-right containing divs for each one, to have the width that is the width of the img it contains. This is so there is a width set on the containers, and it will make the paragraph text wrap correctly and nicely according to the img width. and therefore enabling you to offset the vertical text to the right of the containers.

Here is the modified fiddle for what I did: http://jsfiddle.net/jaredwilli/u26vZ/11/ The script is now just:

var img = $('.img-right, .img-left');
for (var i = 0; i < img.length; i++) {
    $(img[i]).css({ width: $(img[i]).find('img').width() });
}
jaredwilli
  • 11,762
  • 6
  • 42
  • 41
  • 1
    Now that is how you provide some constructive feedback! I will take a look into this now! Thanks Jared! – Joey O Apr 22 '13 at 21:26
  • Was this helpful in solving the problem? If so, can you vote it as the solution? – jaredwilli Apr 23 '13 at 01:05
  • After working with Jared offline of stackoverflow, I believe we've come to the conclusion I was aiming for with this project. Thanks a ton! – Joey O Apr 23 '13 at 14:34
  • It appears the issue is still not resolved... http://jsfiddle.net/jodriscoll/sC2zD/ – Joey O Apr 23 '13 at 17:18