<?xml version="1.0" encoding="utf-8" standalone="yes"?>
<rss version="2.0" xmlns:atom="http://www.w3.org/2005/Atom">
  <channel>
    <title>Generics on David Lang</title>
    <link>https://www.davidlang.tech/tags/generics/</link>
    <description>Recent content in Generics on David Lang</description>
    <generator>Hugo</generator>
    <language>en</language>
    <lastBuildDate>Sat, 28 Aug 2021 00:00:00 +0000</lastBuildDate>
    <atom:link href="https://www.davidlang.tech/tags/generics/index.xml" rel="self" type="application/rss+xml" />
    <item>
      <title>Advanced TypeScript: Generics and Utility Types</title>
      <link>https://www.davidlang.tech/posts/advanced-typescript-generics-and-utility-types/</link>
      <pubDate>Sat, 28 Aug 2021 00:00:00 +0000</pubDate>
      <guid>https://www.davidlang.tech/posts/advanced-typescript-generics-and-utility-types/</guid>
      <description>&lt;p&gt;Generics make functions and types reusable without sacrificing type safety. Utility types transform existing types-essential for API layers and form handling.&lt;/p&gt;&#xA;&lt;h2 id=&#34;generic-functions&#34;&gt;Generic Functions&lt;/h2&gt;&#xA;&lt;div class=&#34;highlight&#34;&gt;&lt;pre tabindex=&#34;0&#34; style=&#34;color:#93a1a1;background-color:#002b36;-moz-tab-size:4;-o-tab-size:4;tab-size:4;-webkit-text-size-adjust:none;&#34;&gt;&lt;code class=&#34;language-typescript&#34; data-lang=&#34;typescript&#34;&gt;&lt;span style=&#34;display:flex;&#34;&gt;&lt;span&gt;&lt;span style=&#34;color:#268bd2&#34;&gt;function&lt;/span&gt; first&amp;lt;&lt;span style=&#34;color:#268bd2&#34;&gt;T&lt;/span&gt;&amp;gt;(arr: &lt;span style=&#34;color:#dc322f&#34;&gt;T&lt;/span&gt;[])&lt;span style=&#34;color:#719e07&#34;&gt;:&lt;/span&gt; T &lt;span style=&#34;color:#719e07&#34;&gt;|&lt;/span&gt; &lt;span style=&#34;color:#cb4b16&#34;&gt;undefined&lt;/span&gt; {&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span style=&#34;display:flex;&#34;&gt;&lt;span&gt;  &lt;span style=&#34;color:#719e07&#34;&gt;return&lt;/span&gt; arr[&lt;span style=&#34;color:#2aa198&#34;&gt;0&lt;/span&gt;];&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span style=&#34;display:flex;&#34;&gt;&lt;span&gt;}&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span style=&#34;display:flex;&#34;&gt;&lt;span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span style=&#34;display:flex;&#34;&gt;&lt;span&gt;&lt;span style=&#34;color:#268bd2&#34;&gt;const&lt;/span&gt; n &lt;span style=&#34;color:#719e07&#34;&gt;=&lt;/span&gt; first([&lt;span style=&#34;color:#2aa198&#34;&gt;1&lt;/span&gt;, &lt;span style=&#34;color:#2aa198&#34;&gt;2&lt;/span&gt;, &lt;span style=&#34;color:#2aa198&#34;&gt;3&lt;/span&gt;]);      &lt;span style=&#34;color:#586e75&#34;&gt;// number | undefined&#xA;&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;span style=&#34;display:flex;&#34;&gt;&lt;span&gt;&lt;span style=&#34;color:#268bd2&#34;&gt;const&lt;/span&gt; s &lt;span style=&#34;color:#719e07&#34;&gt;=&lt;/span&gt; first([&lt;span style=&#34;color:#2aa198&#34;&gt;&amp;#39;a&amp;#39;&lt;/span&gt;, &lt;span style=&#34;color:#2aa198&#34;&gt;&amp;#39;b&amp;#39;&lt;/span&gt;]);     &lt;span style=&#34;color:#586e75&#34;&gt;// string | undefined&#xA;&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/div&gt;&lt;h2 id=&#34;constrained-generics&#34;&gt;Constrained Generics&lt;/h2&gt;&#xA;&lt;div class=&#34;highlight&#34;&gt;&lt;pre tabindex=&#34;0&#34; style=&#34;color:#93a1a1;background-color:#002b36;-moz-tab-size:4;-o-tab-size:4;tab-size:4;-webkit-text-size-adjust:none;&#34;&gt;&lt;code class=&#34;language-typescript&#34; data-lang=&#34;typescript&#34;&gt;&lt;span style=&#34;display:flex;&#34;&gt;&lt;span&gt;&lt;span style=&#34;color:#268bd2&#34;&gt;function&lt;/span&gt; getProperty&amp;lt;&lt;span style=&#34;color:#268bd2&#34;&gt;T&lt;/span&gt;, K extends keyof T&amp;gt;(obj: &lt;span style=&#34;color:#dc322f&#34;&gt;T&lt;/span&gt;, key: &lt;span style=&#34;color:#dc322f&#34;&gt;K&lt;/span&gt;)&lt;span style=&#34;color:#719e07&#34;&gt;:&lt;/span&gt; T[K] {&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span style=&#34;display:flex;&#34;&gt;&lt;span&gt;  &lt;span style=&#34;color:#719e07&#34;&gt;return&lt;/span&gt; obj[key];&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span style=&#34;display:flex;&#34;&gt;&lt;span&gt;}&#xA;&lt;/span&gt;&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/div&gt;&lt;h2 id=&#34;utility-types&#34;&gt;Utility Types&lt;/h2&gt;&#xA;&lt;ul&gt;&#xA;&lt;li&gt;&lt;code&gt;Partial&amp;lt;T&amp;gt;&lt;/code&gt; - all properties optional&lt;/li&gt;&#xA;&lt;li&gt;&lt;code&gt;Pick&amp;lt;T, K&amp;gt;&lt;/code&gt; - subset of keys&lt;/li&gt;&#xA;&lt;li&gt;&lt;code&gt;Omit&amp;lt;T, K&amp;gt;&lt;/code&gt; - exclude keys&lt;/li&gt;&#xA;&lt;li&gt;&lt;code&gt;Record&amp;lt;K, V&amp;gt;&lt;/code&gt; - keyed object type&lt;/li&gt;&#xA;&lt;/ul&gt;&#xA;&lt;div class=&#34;highlight&#34;&gt;&lt;pre tabindex=&#34;0&#34; style=&#34;color:#93a1a1;background-color:#002b36;-moz-tab-size:4;-o-tab-size:4;tab-size:4;-webkit-text-size-adjust:none;&#34;&gt;&lt;code class=&#34;language-typescript&#34; data-lang=&#34;typescript&#34;&gt;&lt;span style=&#34;display:flex;&#34;&gt;&lt;span&gt;&lt;span style=&#34;color:#268bd2&#34;&gt;type&lt;/span&gt; UpdateUserDto &lt;span style=&#34;color:#719e07&#34;&gt;=&lt;/span&gt; Partial&amp;lt;&lt;span style=&#34;color:#268bd2&#34;&gt;Pick&lt;/span&gt;&amp;lt;&lt;span style=&#34;color:#268bd2&#34;&gt;User&lt;/span&gt;, &lt;span style=&#34;color:#2aa198&#34;&gt;&amp;#39;name&amp;#39;&lt;/span&gt; | &lt;span style=&#34;color:#2aa198&#34;&gt;&amp;#39;email&amp;#39;&lt;/span&gt;&amp;gt;&amp;gt;;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/div&gt;&lt;h2 id=&#34;conclusion&#34;&gt;Conclusion&lt;/h2&gt;&#xA;&lt;p&gt;Master generics and utilities before reaching for complex conditional types. They keep DTOs, reducers, and hook return types DRY and accurate.&lt;/p&gt;</description>
    </item>
  </channel>
</rss>
