开发者

Jquery Anchor Elements Moving to New-Line on Hide

I'm new to JQuery (and JavaScript/AJAX in general) and am encountering a problem with hiding elements.

When I use the code below the animation works and the element is hidden but as it is being hidden it is shifted onto a new line along with everything after it. This happens with horizontal hide as well but not with opacity.

Is there a way to stop this from happening or am I missing something out somewhere? The links appear on a line like this:

Related Tags: Tag1 Tag2 Tag3

Code Snippets:

HTML

<script type="text/javascript" src ="JQuery.js"></script>
<script type="text/javascript" src ="test.js"></script>

<strong>Related Tags: </strong>

<a href开发者_JS百科=#>Tag1</a>
<a href=#>Tag2</a>
<a href=#>Tag3</a>

JS

$(function() {
     $("a").click(function(event){
        event.preventDefault();
        $(this).animate({height: 'hide' },"Fast");
    });
});

Thanks in Advance,

Dave


The reason it's happening is that you're animating over the height attribute. Manually setting height would imply block view, and that's why you're being shifted to a new line.

If you don't have a problem with it, you could switch to fadeOut for hiding, and that probably won't cause the same error. Otherwise, the dirty workaround would have to be setting float: left on the anchors. For this to be a neat solution, you'd have to put them in a container, and clear them (because floating objects don't occupy any space in their parent unless they're cleared)

<p>
    <a style="float: left;">...</a>
    <a style="float: left;">...</a>
    <a style="float: left;">...</a>
    <div style="clear: both;"></div>
</p>


Shifting like that probably turns it into a block element, which will put it on a new line will visible. I would suggest:

a { float: left; }

That turns them all into blocks but keeps them side-by-side. I would also suggest using:

$(this).slideUp();

rather than animating height.


The problem is that an inline object cannot have a height specified in HTML. I'm not sure exactly what's happening here but it appears jQuery is compensating by changing the anchor to be a block-level element.

As for how to resolve it, I'm not 100% sure this will work but perhaps if you specify a style of "display: inline-block" for your anchor tags this may resolve the issue (inline-block would allow them to have a height and still behave as you'd expect). If you were to make them all "display: block; float: left;" I'm pretty sure that'd solve it too.

0

上一篇:

下一篇:

精彩评论

暂无评论...
验证码 换一张
取 消

最新问答

问答排行榜