jQuery:使用 .appendTo() 将带有 html 内容的 var 粘贴到标签中

发布于 2024-09-15 08:09:46 字数 922 浏览 11 评论 0原文

我试图粘贴 html 内容(var 中的内容)并将其粘贴到

显然我做错了什么:

function createPreviewBlock(){
        var emptyBlock = '<ul class=emptyList id=previewBlock>' +
                '<li id=periodLi></li>' +
                '<li id=companyLi></li>' +
                '<li id=industryTypeLi></li>' +
                '<li id=idustriaDeEmpresaLi></li>' +
                '<li id=jobTypeLi></li>' +
                '<li id=actionsLi></li>' +
                '</ul>';
        emptyBlock.appendTo('fieldset#previewDataBlock');
        $('ul#previewBlock').removeClass('emptyList').css('display', 'block');

}

因为我收到此错误:

TypeError: emptyBlock.appendTo is not a function { message="emptyBlock.appendTo is not a function",  more...}

Im trying to paste with html content (the one in the var) and paste it in <fieldset id="previewDataBlock">

Obviously Im doing something wrong:

function createPreviewBlock(){
        var emptyBlock = '<ul class=emptyList id=previewBlock>' +
                '<li id=periodLi></li>' +
                '<li id=companyLi></li>' +
                '<li id=industryTypeLi></li>' +
                '<li id=idustriaDeEmpresaLi></li>' +
                '<li id=jobTypeLi></li>' +
                '<li id=actionsLi></li>' +
                '</ul>';
        emptyBlock.appendTo('fieldset#previewDataBlock');
        $('ul#previewBlock').removeClass('emptyList').css('display', 'block');

}

because I'm getting this error:

TypeError: emptyBlock.appendTo is not a function { message="emptyBlock.appendTo is not a function",  more...}

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(2

暮年 2024-09-22 08:09:46

目前它只是一个 HTML 字符串(但仍然是一个 字符串),您需要将其设为 jQuery 对象才能使用 .appendTo() ,像这样:

 $(emptyBlock).appendTo('fieldset#previewDataBlock');

或者只是使用 .append(),像这样:

$('fieldset#previewDataBlock').append(emptyBlock);

顺便说一句,为了更安全,请在属性上使用引号,例如:

    var emptyBlock = '<ul class="emptyList" id="previewBlock">' +

通过像这样混合单引号和双引号,您仍然可以保持它非常干净。

Currently it's just a string of HTML (but still a string), you need to make it a jQuery object to use .appendTo(), like this:

 $(emptyBlock).appendTo('fieldset#previewDataBlock');

Or just use .append(), like this:

$('fieldset#previewDataBlock').append(emptyBlock);

As an aside, to be a bit safer use quotes on your attributes, for example:

    var emptyBlock = '<ul class="emptyList" id="previewBlock">' +

by mixing single and double quotes like this you can still keep it pretty clean.

小镇女孩 2024-09-22 08:09:46

您需要将 emptyblock 放入 jQuery 对象中。

$(emptyblock).appendTo( /* etc*/ );

这是代码的一个更友好的版本:

function createPreviewBlock(){
    $(['<ul class="emptyList" id="previewBlock">',
        '<li id="periodLi"></li>',
        '<li id="companyLi"></li>',
        '<li id="industryTypeLi"></li>',
        '<li id="idustriaDeEmpresaLi"></li>',
        '<li id="jobTypeLi"></li>',
        '<li id="actionsLi"></li>',
        '</ul>'].join(''))
        .appendTo('#previewDataBlock');
    $('#previewBlock').removeClass('emptyList').css('display', 'block');
}

我使用联接而不是串联,因为 IE 6 和 7 在串联时在垃圾收集方面很糟糕。另外,您可以将所有内容直接传递到 jQuery 对象中并避免使用变量。这允许您使用方法链。最后,您只想在选择器中使用 ID。它比在前面添加类似的元素要快。

You need to put emptyblock in a jQuery object.

$(emptyblock).appendTo( /* etc*/ );

Here's a bit friendlier version of your code:

function createPreviewBlock(){
    $(['<ul class="emptyList" id="previewBlock">',
        '<li id="periodLi"></li>',
        '<li id="companyLi"></li>',
        '<li id="industryTypeLi"></li>',
        '<li id="idustriaDeEmpresaLi"></li>',
        '<li id="jobTypeLi"></li>',
        '<li id="actionsLi"></li>',
        '</ul>'].join(''))
        .appendTo('#previewDataBlock');
    $('#previewBlock').removeClass('emptyList').css('display', 'block');
}

I use a join instead of concatenation, because IE 6 and 7 suck at garbage collection when concatenating. Also, you can just pass everything right into the jQuery object and avoid the variable. This allows you to use method chaining. Lastly, you'll want to just use ID's in the selectors. It's faster than prepending with an element like that.

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文