首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Uncaught :对象#<HTMLDivElement>没有“偏移”方法

Uncaught :对象#<HTMLDivElement>没有“偏移”方法
EN

Stack Overflow用户
提问于 2013-12-05 04:38:57
回答 3查看 2.2K关注 0票数 0

我试图动态创建一个元素,然后得到该元素的中心。以下是我所拥有的:

代码语言:javascript
复制
function drawnode(entity, x, y) {

    var ele = ""
    ele += "<div class='relNode'>";
    ele += "<span>" + entity.name() + "</span>"
    ele += "<div>"

    var node = $(ele).appendTo('#rPaper').get(0);
    var offset = node.offset();
    var width = node.width();
    var height = node.height();

    var centerX = offset.left + width / 2;
    var centerY = offset.top + height / 2;

    node.css("top", centerY + y).css("left", centerX + x);

}

这就给出了错误

Object #<HTMLDivElement> has no method 'offset'

我最初尝试了没有.get(0),它没有错误,但高度和宽度都是0。

我做错了什么?

EN

回答 3

Stack Overflow用户

发布于 2013-12-05 04:39:49

您正在尝试调用DOM对象上的DOM函数,因为get给了您DOM对象而不是jQuery对象,使用eq()而不是get()获取jQuery对象

代码语言:javascript
复制
 var node = $(ele).appendTo('#rPaper').eq(0);
票数 3
EN

Stack Overflow用户

发布于 2013-12-05 04:39:22

.get(索引)返回一个dom元素引用,它没有jQuery提供的像抵消()这样的方法。因此,您需要为元素使用jQuery包装器来使用像.offset()/.width()这样的方法

代码语言:javascript
复制
var node = $(ele).appendTo('#rPaper');
票数 0
EN

Stack Overflow用户

发布于 2013-12-05 04:39:43

代码语言:javascript
复制
 var node = $(ele).appendTo('#rPaper');
 var offset = node.offset();
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/20391539

复制
相关文章

相似问题

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