首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >jQuery追加后无图像尺寸

jQuery追加后无图像尺寸
EN

Stack Overflow用户
提问于 2011-10-21 12:56:03
回答 1查看 1.1K关注 0票数 0

我有以下代码,它循环获取表中的所有图像,然后将它们附加到#featured,然后再附加到#wrapper。问题是在所有内容都附加到#wrapper之后,图像没有尺寸,因此没有一个显示出来。它就像图像的宽度和高度都是0px。我该如何克服这个大小问题。

代码语言:javascript
运行
复制
var featured = '<div id="featured"></div>';
$('#imageTable tbody tr td img').each(function(){
    $(featured).append('<img src='+$(this).attr("src")+' />');
});
$(featured).appendTo('#wrapper');

我试着通过这样做来解决这个问题

代码语言:javascript
运行
复制
$(featured).load(function(){
    $(this).appendTo('#wrapper');
});

但这并不管用。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2011-10-21 13:05:07

您的问题是,每次您说$(featured)时,您都在创建一个全新的jQuery对象;然后您对它做了一些操作,然后丢弃了它-以及您对它所做的事情。其结果是,您最终在#wrapper中附加了一个空的<div id="featured">:图像不是没有维度的,它们根本不存在。

创建一个jQuery对象并继续使用该对象:

代码语言:javascript
运行
复制
var $featured = $('<div id="featured"></div>');
$('#imageTable tbody tr td img').each(function(){
    $featured.append('<img src='+$(this).attr("src")+' />');
});
$featured.appendTo('#wrapper');

演示:http://jsfiddle.net/ambiguous/PXVG2/

如果x已经在DOM中,那么一遍又一遍地做$(x).append(...)是可行的;您的<div id="featured">不是这样的东西。如果您首先将其附加到#wrapper,并且#wrapper在DOM中,那么如果您使用#featured而不是HTML:

代码语言:javascript
运行
复制
var featured = '<div id="featured"></div>';
$(featured).appendTo('#wrapper');
$('#imageTable tbody tr td img').each(function(){
    $('#featured').append('<img src='+$(this).attr("src")+' />');
});

演示:http://jsfiddle.net/ambiguous/vPyy6/

后一种方法相当浪费,它在每次.each迭代中创建一个新的jQuery对象。第一种方法要好得多。

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/7845118

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档