-
Notifications
You must be signed in to change notification settings - Fork 71
TypeError: observerHandle is null in Firefox #269
Comments
Hi @TrebuhD, I couldn't reproduce the issue through the website, it seems the content is not being served right now. Would you mind providing a smaller repro through a jsbin? e.g. http://jsbin.com/fowahen/4/edit?html,output Regarding the bug, if |
Hi @valdrinkoshi . I don't know if I'll be able to produce a jsbin repro, as I don't know what exactly causes this error. I use the exact same elements in other places in the code and it works fine there. The site is online now though! We had a small bug on production. You can check out the error over there as described in my original post. I suspect it's a polyfill issue and not a Polymer issue itself - it doesn't happen in Chrome or any browser that has native Shadow DOM/Custom Elements implemented. In any case, I only got this error with |
Just to let you know, I'll soon be swapping the deployed site to a working version without the error (where I manually edited the line in my local |
The website has minified code, and it's hard to add debugging points where I'd want. Can you provide a smaller repro? Skimming through the codebase, I see that there are several nested dom-repeats and dom-ifs, e.g there are 2 nested ifs, here and here. |
Thanks for your answer. I'll try to provide a repro soon. BTW, are nested dom-ifs a bad thing? I had no idea. |
No it's not bad, it's just hard to debug from my side :) I tried following the data flow but got easily lost, and couldn't easily add breakpoints in the places I wanted to in the minified code :/ |
FYI guys, I've faced with the same issue in Edge 16. I've fixed it the same way @TrebuhD is suggesting and have to use a fork of this repo. Here you can see there is no '_observer': It would be great to have this fix merged. |
This looks very much related to a bug in ShadyDOM where listeners weren't actually removed webcomponents/shadydom#190. This was fixed in shadydom v1.0.13, included in webcomponentsjs v1.1.1 - can you confirm you're using either shadydom v1.0.13 or webcomponents v1.1.1? |
@valdrinkoshi I'm using v1.1.1. I'm sorry, I found a piece of code that manually changes It would be convenient to have |
I'm actually facing the same issue, you can reproduce this bug by forcing polyfills on Chrome. <script>
if (window.customElements) window.customElements.forcePolyfill = true;
ShadyDOM = {force: true};
</script>
<script type="text/javascript" src="webcomponentsjs/webcomponents-loader.js"></script> I'm actually forced to override the Why waiting so long to release the fix? |
I'm also having this issue in (at least) FireFox and created a patch on the Polymer.DomApi.prototype.unobserveNodes function like this:
So the difference is just checking if the observerHandle has a value before calling the disconnect function on it. For me this fixes the issue, what could go wrong here? |
+1 !!! |
Any update on this? |
Description
On firefox (v58.02), I get the following error after I destroy one particular element which uses
iron-overlay-behavior
(when navigating to a different route):TypeError: observerHandle is null
The element in question contains a list of elements, each of them using paper-dropdown-menu. When I delete the paper-dropdown-menu, everything works well. If I include paper-dropdown-menu, even one without any content, it throws this error.
The error is particularly bad, because after it occurs, half of the website refuses to work.
The error seems to be coming from this line:
Polymer.dom(this).unobserveNodes(this._observer);
I'm using webcomponents-lite.js.
Expected outcome
No error is thrown
Actual outcome
Error thrown:
TypeError: observerHandle is null
Live Demo & Steps to reproduce
Go to this page, click the downwards facing arrow on the bottom right and then click the green "Pali" button on the left of the element that opened up. The error will occur.
Here's the code for the item containing the dropdown (sc-language-menu on line 200).
Browsers Affected
Stack trace from the error:
The text was updated successfully, but these errors were encountered: