V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
rizon
V2EX  ›  TypeScript

有没有声明 typescript 类型的好办法以及前端样式的健壮性问题

  •  
  •   rizon · 2023-11-23 20:55:29 +08:00 · 1942 次点击
    这是一个创建于 409 天前的主题,其中的信息可能已经有所发展或是发生改变。

    我在学习 react ,看到给一个 div 添加 onMouseDown 事件时,
    这个事件本身的声明是:onMouseDown?: MouseEventHandler<T> | undefined; 写它的实现类时为

      const handleMouseDown = (event:React.MouseEvent<HTMLDivElement,MouseEvent>) => {
    
      }
    

    event 的类型为 MouseEvent ,这个是可以看代码看出来的,但是里面的泛型HTMLDivElement,我这上哪猜去,,,

    1. 虽然不写这么严格也没问题,但是我的问题是基于想要最完整严格的使用 type 的前提。
    2. 这只是举个例子说明我的问题,我核心问题是,typescript 中,编辑器依然不能自动推测出所有的字段类型,对于编辑器无法推测的情况下,我该如何去更好的面对和解决这个问题呢。
    3. 前端样式有什么好的规范文档吗,我是自学的,虽然能写出样式来,但是代码的健壮性、优雅等各方面差太多了,有什么更系统的学习材料吗
    7 条回复    2023-11-26 12:46:39 +08:00
    thinkershare
        1
    thinkershare  
       2023-11-23 21:48:09 +08:00
    为什么需要猜了,HTML 的 DIV 元素的接口类型就是 HTMLDivElement 。
    ragnaroks
        2
    ragnaroks  
       2023-11-23 22:46:39 +08:00
    另外,type MouseEventHandler<T> = (event:MouseEvent<T>)=>void
    molvqingtai
        3
    molvqingtai  
       2023-11-24 00:32:31 +08:00
    你还可以直接写 tag 名称
    import React from "react";

    const onChange: React.ComponentProps<"input">["onChange"] =
    (e) => {
    console.log(e);
    };

    <input onChange={onChange} />;
    molvqingtai
        4
    molvqingtai  
       2023-11-24 00:37:32 +08:00
    如果不确定那种 DOM 触发的事件,可以使用 SyntheticEvent
    magicdawn
        5
    magicdawn  
       2023-11-24 02:17:22 +08:00   ❤️ 1
    Al0rid4l
        6
    Al0rid4l  
       2023-11-24 15:26:43 +08:00
    因为他默认你一看这名字就知道这是 Web API 的接口, 所以

    https://developer.mozilla.org/en-US/docs/Web/API/HTMLDivElement

    其他 DOM API/Web API 都在 MDN 查就完事了
    rizon
        7
    rizon  
    OP
       2023-11-26 12:46:39 +08:00
    @magicdawn #5 嘿,这是个好玩意,可以给出不少指导建议。nice ~
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   2990 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 25ms · UTC 13:00 · PVG 21:00 · LAX 05:00 · JFK 08:00
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.