我试图让我的div“tick_list”的第一个孩子插入新元素,但它返回undefined。
$(function() {
var tick_list = $('#tick_list');
socket.on('tick', function(data){
console.log(tick_list.firstElementChild);
});
});
答案 0 :(得分:3)
tick_list
是一个jQuery对象,它没有firstElementChild
属性。
您可以使用tick_list.children().eq(0)
来获取第一个子节点(仍然是jQuery对象)。
有很多方法可以获得第一个孩子,这里有一个 jsperf test :
答案 1 :(得分:1)
$(function() {
var tick_list = $('#tick_list');
socket.on('tick', function(data){
console.log(tick_list.eq(0));
});
});
答案 2 :(得分:1)
$(function() {
var tick_list = $('#tick_list');
socket.on('tick', function(data){
console.log(tick_list.children(':first'));
});
});
答案 3 :(得分:1)
您可以使用children()和first()jquery方法
$(function() {
var tick_list = $('#tick_list');
socket.on('tick', function(data){
console.log(tick_list.children().first());
});
});
答案 4 :(得分:0)
tick_list
是一个jQuery对象,因此您无法使用成员运算符直接访问dom属性。
您使用use .prop()方法
tick_list.prop('firstElementChild')
或使用索引.get()
访问底层dom元素tick_list[0].firstElementChild