<?xml version="1.0" encoding="utf-8" standalone="yes"?><rss version="2.0" xmlns:atom="http://www.w3.org/2005/Atom"><channel><title>Debugging on Dan's Blog</title><link>https://blog.danfrevel.de/tags/debugging/</link><description>Recent content in Debugging on Dan's Blog</description><generator>Hugo</generator><language>en-us</language><lastBuildDate>Mon, 02 Feb 2026 00:00:00 +0000</lastBuildDate><atom:link href="https://blog.danfrevel.de/tags/debugging/index.xml" rel="self" type="application/rss+xml"/><item><title>Debugging Angular Signals: A Quick Trick</title><link>https://blog.danfrevel.de/posts/angular-signal-debugging/</link><pubDate>Mon, 02 Feb 2026 00:00:00 +0000</pubDate><guid>https://blog.danfrevel.de/posts/angular-signal-debugging/</guid><description>&lt;p&gt;Signals don&amp;rsquo;t show up in the regular change detection logs. When something&amp;rsquo;s not updating and you can&amp;rsquo;t figure out why, drop an &lt;code&gt;effect()&lt;/code&gt; in your component:&lt;/p&gt;
&lt;div class="highlight"&gt;&lt;pre tabindex="0" style="color:#f8f8f2;background-color:#282a36;-moz-tab-size:4;-o-tab-size:4;tab-size:4;"&gt;&lt;code class="language-typescript" data-lang="typescript"&gt;&lt;span style="display:flex;"&gt;&lt;span&gt;&lt;span style="color:#ff79c6"&gt;import&lt;/span&gt; { effect, signal, computed } &lt;span style="color:#ff79c6"&gt;from&lt;/span&gt; &lt;span style="color:#f1fa8c"&gt;&amp;#39;@angular/core&amp;#39;&lt;/span&gt;;
&lt;/span&gt;&lt;/span&gt;&lt;span style="display:flex;"&gt;&lt;span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span style="display:flex;"&gt;&lt;span&gt;&lt;span style="color:#ff79c6"&gt;export&lt;/span&gt; &lt;span style="color:#ff79c6"&gt;class&lt;/span&gt; CartComponent {
&lt;/span&gt;&lt;/span&gt;&lt;span style="display:flex;"&gt;&lt;span&gt; items &lt;span style="color:#ff79c6"&gt;=&lt;/span&gt; signal&amp;lt;&lt;span style="color:#ff79c6"&gt;CartItem&lt;/span&gt;[]&amp;gt;([]);
&lt;/span&gt;&lt;/span&gt;&lt;span style="display:flex;"&gt;&lt;span&gt; total &lt;span style="color:#ff79c6"&gt;=&lt;/span&gt; computed(() &lt;span style="color:#ff79c6"&gt;=&amp;gt;&lt;/span&gt; &lt;span style="color:#ff79c6"&gt;this&lt;/span&gt;.items().reduce((sum, i) &lt;span style="color:#ff79c6"&gt;=&amp;gt;&lt;/span&gt; sum &lt;span style="color:#ff79c6"&gt;+&lt;/span&gt; i.price, &lt;span style="color:#bd93f9"&gt;0&lt;/span&gt;));
&lt;/span&gt;&lt;/span&gt;&lt;span style="display:flex;"&gt;&lt;span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span style="display:flex;"&gt;&lt;span&gt; &lt;span style="color:#ff79c6"&gt;constructor&lt;/span&gt;() {
&lt;/span&gt;&lt;/span&gt;&lt;span style="display:flex;"&gt;&lt;span&gt; effect(() &lt;span style="color:#ff79c6"&gt;=&amp;gt;&lt;/span&gt; {
&lt;/span&gt;&lt;/span&gt;&lt;span style="display:flex;"&gt;&lt;span&gt; console.log(&lt;span style="color:#f1fa8c"&gt;&amp;#39;items changed:&amp;#39;&lt;/span&gt;, &lt;span style="color:#ff79c6"&gt;this&lt;/span&gt;.items());
&lt;/span&gt;&lt;/span&gt;&lt;span style="display:flex;"&gt;&lt;span&gt; console.log(&lt;span style="color:#f1fa8c"&gt;&amp;#39;total is now:&amp;#39;&lt;/span&gt;, &lt;span style="color:#ff79c6"&gt;this&lt;/span&gt;.total());
&lt;/span&gt;&lt;/span&gt;&lt;span style="display:flex;"&gt;&lt;span&gt; });
&lt;/span&gt;&lt;/span&gt;&lt;span style="display:flex;"&gt;&lt;span&gt; }
&lt;/span&gt;&lt;/span&gt;&lt;span style="display:flex;"&gt;&lt;span&gt;}
&lt;/span&gt;&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/div&gt;&lt;p&gt;The &lt;code&gt;effect()&lt;/code&gt; runs whenever any signal it reads changes. It automatically tracks dependencies — no need to specify what to watch.&lt;/p&gt;</description></item></channel></rss>