我正在重构一些旧的JavaScript代码,其中有很多DOM操作。

var d = document;
var odv = d.createElement("div");
odv.style.display = "none";
this.OuterDiv = odv;

var t = d.createElement("table");
t.cellSpacing = 0;
t.className = "text";
odv.appendChild(t);

我想知道是否有一个更好的方法来做到这一点使用jQuery。我一直在尝试:

var odv = $.create("div");
$.append(odv);
// And many more

但我不确定这样是否更好。


当前回答

我是这样做的:

$('<div/>',{
    text: 'Div text',
    class: 'className'
}).appendTo('#parentDiv');

其他回答

创建新的DOM元素是jQuery()方法的核心特性,请参见:

http://api.jquery.com/jQuery/#creating-new-elements 特别是http://api.jquery.com/jQuery/#example-1-1

我是这样做的:

$('<div/>',{
    text: 'Div text',
    class: 'className'
}).appendTo('#parentDiv');
var div = $('<div/>');
div.append('Hello World!');

是在jQuery中创建DIV元素的最短/最简单的方法。

例如,当你想在<select> ! <option>元素中添加<option>

$('<option/>')
  .val(optionVal)
  .text('some option')
  .appendTo('#mySelect')

显然可以应用于任何元素

$('<div/>')
  .css('border-color', red)
  .text('some text')
  .appendTo('#parentDiv')

更新

在jQuery的最新版本中,下面的方法不分配传递给第二个对象的属性

以前的回答

我觉得使用document.createElement('div')与jQuery一起使用更快:

$(document.createElement('div'), {
    text: 'Div text',
    'class': 'className'
}).appendTo('#parentDiv');