首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在使用ng-重复和限制-和从jQuery获得工具提示时,在tether.js中获取上下文错误

在使用ng-重复和限制-和从jQuery获得工具提示时,在tether.js中获取上下文错误
EN

Stack Overflow用户
提问于 2014-11-12 02:07:12
回答 2查看 2.1K关注 0票数 6

首先,我知道这是个了不起的头衔。

我最近接管了angular-tooltip,并试图为我的主要工作项目构建一个自定义工具提示。

在我的项目中,我有一个ng-重复指令,简单地说

代码语言:javascript
复制
<div class="row-submenu-white" ng-repeat="merge in potentialMerges | limitTo: numPotentialMergesVisible" company-profile-tooltip="merge.preview"></div>

使用库的说明,我定义了一个自定义工具提示指令:

代码语言:javascript
复制
myApp.directive('companyProfileTooltip', ['$tooltip', ($tooltip) => {
    return {
        restrict: 'EA',
        scope: { profile: '@companyProfileTooltip' },
        link: (scope: ng.IScope, elem) => {
            var tooltip = $tooltip({
                target: elem,
                scope: scope,
                templateUrl: "/App/Private/Content/Common/company.profile.html",
                tether: {
                    attachment: 'middle right',
                    targetAttachment: 'middle left',
                    offset: '0 10px'
                }
            });

            $(elem).hover(() => {
               tooltip.open();
           }, () => {
                tooltip.close();
           });
        }
    };
}]);

Company.profile.html只是:

代码语言:javascript
复制
<div>Hello, world!</div>

现在,如果你注意到,在ng-重复我有一个limitTo过滤器。对于每一个合并(初始化为3),合并都非常完美,其中适当添加了<div>Hello, world!</div>工具提示。

然后触发limitTo,将其限制为更大的数目。初始3之后的每个重复元素都会给出以下错误:

代码语言:javascript
复制
TypeError: context is undefined


if ( ( context.ownerDocument || context ) !== document ) {

这个错误出现在jquery-2.1.1.js中,调试在我头上似乎是无可救药的。

我能告诉你的是,为这一行调用的函数是

代码语言:javascript
复制
Sizzle.contains = function( context, elem ) {
    // Set document vars if needed
    if ( ( context.ownerDocument || context ) !== document ) {
        setDocument( context );
    }
    return contains( context, elem );
};

的调用堆栈

代码语言:javascript
复制
Sizzle</Sizzle.contains(context=Document 046f7364-fa8d-4e95-e131-fa26ae78d108, elem=div)jquery-2.1.1.js (line 1409)
.buildFragment(elems=["<div>\r\n Hello, world!\r\n</div>"], context=Document 046f7364-fa8d-4e95-e131-fa26ae78d108, scripts=false, selection=undefined)jquery-2.1.1.js (line 5123)
jQuery.parseHTML(data="<div>\r\n Hello, world!\r\n</div>", context=Document 046f7364-fa8d-4e95-e131-fa26ae78d108, keepScripts=true)jquery-2.1.1.js (line 8810)
jQuery.fn.init(selector="<div>\r\n Hello, world!\r\n</div>\r\n", context=undefined, rootjQuery=undefined)jquery-....2.1.js (line 221)
jQuery(selector="<div>\r\n Hello, world!\r\n</div>\r\n", context=undefined)jquery-2.1.1.js (line 76)
compile($compileNodes="<div>\r\n Hello, world!\r\n</div>\r\n", transcludeFn=undefined, maxPriority=undefined, ignoreDirective=undefined, previousCompileContext=undefined)angular.js (line 6812)
m()angular....min.js (line 2)
.link/<()app.js (line 262)
jQuery.event.special[orig].handle(event=Object { originalEvent=Event mouseover, type="mouseenter", timeStamp=0, more...})jquery-2.1.1.js (line 4739)
jQuery.event.dispatch(event=Object { originalEvent=Event mouseover, type="mouseenter", timeStamp=0, more...})jquery-2.1.1.js (line 4408)
jQuery.event.add/elemData.handle(e=mouseover clientX=980, clientY=403)jquery-2.1.1.js (line 4095)

App.js第262行是上面提供的指令的链接函数。

在我的生活中,我无法弄清楚是什么使在初始limitTo增加之后重复的元素中没有定义上下文。我可以验证的是,删除limitTo过滤器会导致每个元素的行为在整个过程中都很好。我还可以验证的是,如果我将初始limitTo值设置为0并在之后将其增加,那么初始的3个元素就不能工作。

查看limitTo的源代码使我相信,每次您限制更改的数量都会构造一个新的数组。就我的理解而言,这应该会导致角移除所有DOM元素,然后更改它们,但我无法判断这种更改是否会以任何方式影响到这一点。

我知道没有什么可做的,但我不知道如何调试它,我可以感谢任何帮助,或者如果在ng中有任何行为,重复一遍我不知道这可以解释这一点。

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2014-11-14 00:41:14

显然,问题是错误的数据被缓存在角工具提示库中。对模板的整个请求正在被解析,而不仅仅是它的内容。这个问题与ngRepeat无关;limitTo之前的第一个n项将触发GET请求,因为模板数据尚未填充templateCache,但稍后它们将尝试访问整个请求的内容。

票数 0
EN

Stack Overflow用户

发布于 2014-11-13 08:16:10

我想,当您更新elem时,numPotentialMergesVisible并没有“足够快”地添加到dom中。

尝试以下几点:

代码语言:javascript
复制
myApp.directive('companyProfileTooltip', ['$tooltip', ($tooltip) => {
    return {
        restrict: 'EA',
        scope: { profile: '@companyProfileTooltip' },
        link: (scope: ng.IScope, elem) => {
            var tooltip = $tooltip({
                target: elem,
                scope: scope,
                templateUrl: "/App/Private/Content/Common/company.profile.html",
                tether: {
                    attachment: 'middle right',
                    targetAttachment: 'middle left',
                    offset: '0 10px'
                }
            });
             $timeout(()=> {
                $(elem).hover(() => {
                   tooltip.open();
               }, () => {
                    tooltip.close();
               });
           },1);
        }
    };
}]);

这样,悬停设置方法将在处理$scope变量值更改后执行。

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

https://stackoverflow.com/questions/26878052

复制
相关文章

相似问题

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