Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Uncaught TypeError: Cannot read property 'data' of null #169

Open
speedplane opened this issue Jul 27, 2018 · 3 comments
Open

Uncaught TypeError: Cannot read property 'data' of null #169

speedplane opened this issue Jul 27, 2018 · 3 comments
Labels
Bug Software defects or other problems that should be fixed.

Comments

@speedplane
Copy link

I'm running powertip 1.3.1 and got the following exception:

jquery.powertip.js:964 Uncaught TypeError: Cannot read property 'data' of null
    at hideTip (jquery.powertip.js:964)
    at showTip (jquery.powertip.js:855)
    at HTMLDivElement.queueTipInit (jquery.powertip.js:829)
    at Function.dequeue (js_thirdp_libs.js:20)
    at HTMLDivElement.r.complete (js_thirdp_libs.js:20)
    at l (js_thirdp_libs.js:20)
    at Object.fireWith [as resolveWith] (js_thirdp_libs.js:20)
    at a (js_thirdp_libs.js:20)
    at v.fx.tick (js_thirdp_libs.js:20)

This was occuring while I was hovering over something with a powerTip, and an event comes in which causes another powerTip to open. It's not entirely consistent, and I believe it has todo with the opening and closing state of the hovered powertip.

As shown in the debugger below, it looks like isTipOpen is true, and it isn't closing, but activeHover is null.

image

@george-dragnea
Copy link

Have you manage to solve it ?

@stevenbenner
Copy link
Owner

I apologize for the severely delayed response. I haven’t had much time to spend on personal projects lately.

This is very peculiar error indeed. This issue is very similar to issue #165, but the error is showing up at a different point in the script.

Other than the session object initialization, there is only one place in the code where session.activeHover is set to null:

// reset session and tooltip element
session.activeHover = null;
session.isClosing = false;
session.isFixedTipOpen = false;
tipElement.removeClass();

Which is in the fadeOut() completed callback in the hideTip() function. The session.isClosing property is set to true as soon as the hideTip() function is invoked to prevent exactly this situation. The hideTip() invocation in the debugger screen shot is wrapped in an if (!session.isClosing) check which is supposed to prevent erroneous repeated calls.

Based on the error, it looks like it failed at the element.data(DATA_HASACTIVEHOVER, false); line in the hideTip() function.

I’m not sure what’s going on here. I can think of a couple possibilities:

  • The hideTip method got called more than once for the previous element.
  • The hideTip method got called on the current element during the tooltip open.
  • The jQuery object that was passed to PowerTip got destroyed/garbage-collected unexpectedly.

But, without being able to see the code and debug it, I’m limited to guessing. I don’t see anything obvious that would allow this state to arise. I could add a session state check to the hideTip() function, but without knowing what the root cause is, I am hesitant to do so because it might just move the problem somewhere else and make it harder to debug the next time it arrises.

So I have a couple debugging questions:

  • Can you show me the code you’re using to run PowerTip? (Or provide a reduced test case/example that I can play with?)
  • Does this happen on other browsers?
  • What version of jQuery are you using?
  • Are the elements you’re adding tooltips to every dynamically added or removed from the page?

@stevenbenner stevenbenner added the Bug Software defects or other problems that should be fixed. label Sep 23, 2018
@yordis
Copy link

yordis commented May 26, 2019

@stevenbenner

Can you show me the code you’re using to run PowerTip? (Or provide a reduced test case/example that I can play with?)

.powerTip({ placement: 'se', intentPollInterval: 300 });

Does this happen on other browsers?

Chrome only

What version of jQuery are you using?

1.7.2

Are the elements you’re adding tooltips to every dynamically added or removed from the page?

Yes

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Bug Software defects or other problems that should be fixed.
Projects
None yet
Development

No branches or pull requests

4 participants