タグ

jay-esのブックマーク (2,077)

  • Preview Docs - Visual Studio Marketplace

    VSCode Preview Docs ✨ This VSCode extension enables you to preview language and framework documentations directly within your IDE ✨. Preview Docs automatically scans your package.json file and generates documentation specific to each language and framework. Preview Docs supports over 300+ documentation sites. Preview Docs How to contribute? Contributions are welcome and encouraged! If you have any

    jay-es
    jay-es 2024/01/28
    プロジェクト内で使用しているライブラリーのドキュメントを一覧&表示できる VS Code 拡張
  • GitHub - rajnandan1/kener: Kener is a Modern Self hosted Status Page, batteries included

    Kener: Open-source Node.js status page tool, designed to make service monitoring and incident handling a breeze. It offers a sleek and user-friendly interface that simplifies tracking service outages and improves how we communicate during incidents. And the best part? Kener integrates seamlessly with GitHub, making incident management a team effort—making it easier for us to track and fix issues t

    GitHub - rajnandan1/kener: Kener is a Modern Self hosted Status Page, batteries included
    jay-es
    jay-es 2024/01/28
    ステータスページを作るためのキット。SvelteKit ベース
  • GitHub - unadlib/mutative: Efficient immutable updates, 2-6x faster than naive handcrafted reducer, and more than 10x faster than Immer.

    You signed in with another tab or window. Reload to refresh your session. You signed out in another tab or window. Reload to refresh your session. You switched accounts on another tab or window. Reload to refresh your session. Dismiss alert

    GitHub - unadlib/mutative: Efficient immutable updates, 2-6x faster than naive handcrafted reducer, and more than 10x faster than Immer.
    jay-es
    jay-es 2024/01/28
    Immer 代替。10倍高速らしい
  • Next.js App Router キャッシュの今

    先日Vercelから「Next.js App Router Caching: Explained!」というタイトルの動画が公開されていたので、その内容をまとめることでNext.jsのキャッシュの今について整理しておこうと思います。 基 まずNext.jsでは、静的レンダリングがデフォルトです。RSCを使用していても基的にはビルド時にページが事前レンダリングされます。これはRoute Handlersも同様です。仮にビルド後にデータを更新してもリビルドしない限り表示は古いままであり、これは静的にレンダリングされていると言えます。 ただし、developmentとproductionでは挙動が異なります。ローカルではコードに変更を加えるたびにデータが再取得・レンダリングされるので、ローカルとビルド後の挙動に違いがあることを理解しておきましょう。 リクエストするたびに最新のデータを取得し表示

    Next.js App Router キャッシュの今
    jay-es
    jay-es 2024/01/28
    "ただし、developmentとproductionでは挙動が異なります。" ←これはキャッシュ以外でもいくつかあり、「ビルドしたら期待通りに動かなかった」が起こりがちなのが App Router のつらいところ
  • GitHub - microsoft/typespec

    Official Docs | Try TypeSpec Online | Getting Started | Language Overview TypeSpec is a language for defining cloud service APIs and shapes. TypeSpec is a highly extensible language with primitives that can describe API shapes common among REST, OpenAPI, gRPC, and other protocols. TypeSpec is excellent for generating many different API description formats, client and service code, documentation, a

    GitHub - microsoft/typespec
    jay-es
    jay-es 2024/01/28
    TypeScript にインスパイアされた、API 定義のための軽量言語。Open API や JSON Schema などに対応
  • イベントハンドラの関数名についての雑記 - Qiita

    今日のXでは、イベントハンドラの関数名についての話題を見ました。元の投稿はこちらです。要するに、次のhandleClickのようなhandleイベント名という命名は良くないということです。 const handleClick = () => { ... }; <button type="button" onClick={handleClick} /> これについて少し考えたので、せっかくなのでアウトプットしておくことにしました。 この記事の目的 考えたことを頭の中に残しておくのがもったいないので、文章の形にしておく。 色々な意見が出る問題であり、ベストな答えは無いので各々好きにすれば良いということを、読者に理解してもらう。 とはいえ、筆者の考えに納得して同じ考えの人が多いと嬉しいので、なるべく納得してもらう。 筆者の考え 自分の考えとしては、むしろhandleClickいいじゃん! どんど

    イベントハンドラの関数名についての雑記 - Qiita
    jay-es
    jay-es 2024/01/26
    わかる。React だろうが Vue だろうがイベントハンドラーとしての役割であれば handleClick みたいな命名をするし、onClick や v-on:click に addUser のような関数を直接渡すのもよくやる
  • 単体テストの考え方/使い方 まとめ

    著者は古典学派のスタイルを好んでいて、書では古典学派の定義を採用している テスト対象の焦点をクラスに当てるのは間違っていて、1単位の振る舞いに焦点を当てなければいけない。 また、ロンドン学派のスタイルだと単体テストがテスト対象の内部的なコードと密接に結びつく傾向があるため、賛同できない。 3章 単体テストの構造的解析 AAAパターンという単体テストの構造を用いることで、全てのテストケースに対して簡潔で統一された構造を持たせることができる。また、この構造に慣れることで読みやすさが向上し、保守コストを下げることにつながる。 準備フェーズ(Arrange)フェーズ...ケースの事前条件を満たすように、テスト対象システムとその依存の状態を設定するフェーズ 実行(Act)フェーズ...テスト対象の振る舞いを実行するフェーズ 確認(Assert)フェーズ...実行した結果が想定した結果であることを確

    単体テストの考え方/使い方 まとめ
  • うひょさん、よしこさんと改めて考えるReactコンポーネント設計 | Offers Magazine

    はじめに 佐藤:佐藤歩です。現職では開発からしばらく離れていたんですが、最近またまとまった量のリプレイス開発に携わってるので、モデレーターとして、よしこさん、うひょさんからいろいろお話を伺っていきたいなと思っております。 よしこ:こんばんは。よしこです。株式会社ナレッジワークに創業期に入社し、フロントエンドエンジニアをしています。プロダクトの0→1のところから、今の1→10のフェーズに入るまで、SPAのアプリケーション設計や運用をしてきました。 うひょ:うひょです。株式会社バベルに在籍しています。これまでずっとTypeScriptReactフロントエンドのアプリ開発に携わってきました。昨年はTypeScriptに関するも出版しています。 佐藤:今回は、Reactのコンポーネント設計におけるこちらの5つのテーマごとに、よしこさんとうひょさんに順番に簡単にお話をしていただきつつ、都度ディ

    うひょさん、よしこさんと改めて考えるReactコンポーネント設計 | Offers Magazine
  • RemixでWeb標準を学んだ1年間 / First year with Remix

    フロントエンド技術選定 ~2023を振り返る~ Lunch LT での発表資料です https://findy.connpass.com/event/306714/

    RemixでWeb標準を学んだ1年間 / First year with Remix
  • コンテキスト - GitHub Docs

    コンテキストについて コンテキストは、ワークフローの実行、変数、ランナーの環境、ジョブ、ステップに関する情報にアクセスする方法です。 各コンテキストは、プロパティを含むオブジェクトであり、文字列またはその他のオブジェクトにすることができます。 コンテキスト、オブジェクト、プロパティは、ワークフローの実行条件によって大きく異なります。 たとえば、matrix コンテキストはマトリックス内のジョブに対してのみ設定されます。 式構文を使用してコンテキストにアクセスできます。 詳しくは、「式」を参照してください。 ${{ <context> }} 警告: ワークフローとアクションを作成するときは、コードが攻撃者からの信頼されていない入力を実行する可能性があるかどうかを常に考慮する必要があります。 攻撃者が悪意あるコンテンツを挿入してくるかもしれないので、特定のコンテキストは信頼できない入力として扱

    コンテキスト - GitHub Docs
    jay-es
    jay-es 2024/01/24
    GitHub Actions 内で使う `github` や `env` のドキュメント
  • htmxとは何なのか? その背景にある思想について - Qiita

    先日、Qiitaに投稿された一つの記事が注目を集めました。 元記事では、htmxというJavaScriptライブラリが英語圏で認知を獲得しているとして、インストールの仕方から使い方について公式のドキュメントの全体にわたって簡単に説明が行われています。 さまざまなプラットフォームでこの記事に対する反応を観察してみると、どちらかというと懐疑的な見方のほうが優勢のように見受けられます。ただ、多くのコメントは誤解に基づいているように見受けられました。「JSが要らない」といった元記事のミスリードによるところも大きそうですが1、なぜhtmxが大きく支持を得つつあるのかを理解するには、背景情報を含めて理解することが必要です。 htmxは、最近の複雑化するフロントエンド技術に対する単なる逆張りではありません。これまで30年ほどのあいだウェブ上のシステムを支え続けた「ハイパーメディア」の持つ強力さに今一度目

    htmxとは何なのか? その背景にある思想について - Qiita
  • GitHub - pi0/tired-maintainer: 🗒️ Notes from a tired maintainer

    Hi. You might have come across this text either because you found it somehow or with a link, perhaps in a closed Pull-Request (PR) Issue or a chat. If you are coming from a closed issue or PR, before everything THANK YOU for your contributions and help, i do appreciate that ❤️ The thing is, maintaining multiple open-source projects is not as easy as you might imagine. As a full-time open-source ma

    GitHub - pi0/tired-maintainer: 🗒️ Notes from a tired maintainer
    jay-es
    jay-es 2024/01/23
    OSS のメンテナーは大量の通知やメッセージが来る。PR がすぐマージできないことには理由がある。催促やめて。連絡する際は詳細な情報を添えて欲しい
  • エンジニアやデザイナーがやっているポッドキャスト更新まとめ

    はい!第402回は,自分が今後登壇する勉強会のテーマのために最近調査し直している話の一つとして,JavaScript のフレームワークの変遷について軽くお話してみました💁‍♂ではでは(=゚ω゚)ノーーーーー🔗 LINKSObject-Oriented Conference 2024https://ooc.dev/2024/設計カンファレンス extends OOChttps://yumemi.connpass.com/event/310541/♪ BGM騒音のない世界「天晴」https://soundcloud.com/baron1_3/appareSee Privacy Policy at https://art19.com/privacy and California Privacy Notice at https://art19.com/privacy#do-not-sell-m

    エンジニアやデザイナーがやっているポッドキャスト更新まとめ
  • Designing better target sizes

    Intro As a user, you need to interact with clickable UI elements like buttons, links, cards, and more. If an action has a small target size, it will be harder for the user to click, or they might click an adjacent action element by mistake. Let’s take a look at the following example.

    Designing better target sizes
  • PostgreSQLでは識別子に大文字を使ってはいけない - Qiita

    タイトルの通り、PostgreSQLではテーブル名、カラム名など識別子に英大文字を使うべきではありません。 PostgreSQLは命令中の識別子を読み取るとき、二重引用符でくくられていなければ大文字を小文字に正規化します。その上で大文字小文字を区別して認識します。 その結果、 PgAdminでUsersテーブルを作る ツールはちゃんと二重引用符でくくるのでそのままの名前でテーブルができる コード内でselect id, name from Usersなどと書くと、select id, name from usersと解釈されてしまいテーブルが見つからない などという馬鹿馬鹿しい事故が起こることになります。 手書きでSQLを書くならまだしも、O/Rマッパーが絡んだりするとや闇要素でてきますね。 (人のブログ記事 http://cs.hatenablog.jp/entry/2014/05/3

    PostgreSQLでは識別子に大文字を使ってはいけない - Qiita
    jay-es
    jay-es 2024/01/21
    “PostgreSQLは命令中の識別子を読み取るとき、二重引用符でくくられていなければ大文字を小文字に正規化します”
  • Compiling a standalone executable using modern JavaScript/TypeScript runtimes

    You signed in with another tab or window. Reload to refresh your session. You signed out in another tab or window. Reload to refresh your session. You switched accounts on another tab or window. Reload to refresh your session. Dismiss alert

    Compiling a standalone executable using modern JavaScript/TypeScript runtimes
    jay-es
    jay-es 2024/01/20
    Node.js, Deno, Bun で実行可能ファイルを作る方法まとめ
  • Difference between getElementByID and querySelector

    Assume you have a valid HTML element in DOM. I assumed the following snippets to be the same. let id = "037e3778-e157-4715-bff5-e466230fe7a3" const byId = document.getElementById(id) console.log(byId) // works const bySelectorConcat = document.querySelector("#" + id) console.log(bySelectorConcat) // Uncaught DOMException: Failed to execute 'querySelector' on 'Document': '#037e3778-e157-4715-bff5-e

    Difference between getElementByID and querySelector
    jay-es
    jay-es 2024/01/20
    数字で始まる id 属性は(正当な HTML だが)CSS セレクターとしては不正なので、単純に # をつけるだけだと document.querySelector で取得できない。`[id='${id}']` や `#${CSS.escape(id)}` にする必要がある
  • すべてのフロントエンド デベロッパーが知っておくべき 5 つの CSS スニペット(2024 年)  |  Articles  |  web.dev

    すべてのフロントエンド デベロッパーが知っておくべき 5 つの CSS スニペット(2024 年) コレクションでコンテンツを整理 必要に応じて、コンテンツの保存と分類を行います。 すべてのフロントエンド デベロッパーは、:has() が「親セレクタ」以上のものであること、subgrid の仕組みと理由、組み込みの CSS 構文でネストする方法、ブラウザで見出しテキストの折り返しのバランスを取る方法、コンテナクエリ ユニットの使用方法について知っておくべきだと思います。 この投稿は、すべてのフロントエンド デベロッパーが知っておくべき昨年 2023 年の 6 つの CSS スニペットの続きです。 CSS:has(.potential-beyond-being-a-parent-selector) :has() は 2023 年末に、すべての主要なブラウザでリリースされました。この新しいセレ

    jay-es
    jay-es 2024/01/20
    :has, subgrid, nesting, text-wrap の balance と pretty, コンテナを基準にしたサイズ単位(cqi, cqw など)
  • The Golden Rule of Assertions

    What if I told you there was a single rule that can reliably tell apart a good test from a bad one? This is not a trick, not a sales pitch. It’s a rule I’ve been using for years to help me refine my tests, make them less flaky and more valuable countless times. In fact, it’s such an indispensable rule in practice that I hereby coin it The Golden Rule of Assertions: A test must fail if, and only if

    The Golden Rule of Assertions
    jay-es
    jay-es 2024/01/20
    「テストが失敗するのは、システムの意図が達成されない場合のみでなければいけない」 。対応の一例として、実装の詳細はテストしない、外部要因(API など)に依存するコードの場合はモックを使用する、など
  • What PWA Can Do Today

    A showcase of what is possible with Progressive Web Apps today. A Progressive Web App (PWA) is a website that can be installed on your device and provide an app-like experience read more How to use this app This app is itself a Progressive Web App which means it can be installed to the home screen of your mobile device or to your desktop. After installing you can check the demos of the features be

    What PWA Can Do Today
    jay-es
    jay-es 2024/01/20
    PWA でできること一覧とその実装方法