Follow

Keep Up to Date with the Most Important News

By pressing the Subscribe button, you confirm that you have read and are agreeing to our Privacy Policy and Terms of Use
Contact

What type is passed to functions from `onClick`?

I have some javascript that looks like this:

const menu = (
        <Menu onClick={handleMenuClick}>
            {menuItems.map((item) => (
                <Menu.Item key={item.key} icon={item.icon} style={styles.item}>
                    <span style={{ marginLeft: "5px" }}>{item.value}</span>
                </Menu.Item>
            ))}
        </Menu>
    )

With the key piece being the handleMenuClick

That function is defined as:

MEDevel.com: Open-source for Healthcare and Education

Collecting and validating open-source software for healthcare, education, enterprise, development, medical imaging, medical records, and digital pathology.

Visit Medevel

    const handleMenuClick = (event) => {
        console.log(event.key)
        console.log(typeof (event.key))
    }

However, I’m not sure what type the event is, and how it’s getting the key value?

Additionally, when I try this in typescript, it looks like its a Synthetic event. However, I try to access the key value with e.target.value and I keep getting errors.

So I’m not sure what I’m not understanding

>Solution :

When you have a TS function that takes a callback, and you want to define the callback elsewhere but aren’t sure of the right typing to use, first write the function inline with the callback, and use an IDE that can tell you the types of variables. Then look at the type of the variable:

enter image description here

Then copy that type when defining a standalone callback that you can pass in.

This works not only for onClick in React, but for any situation where you’re dealing with a callback you don’t know the proper type for.

Add a comment

Leave a Reply

Keep Up to Date with the Most Important News

By pressing the Subscribe button, you confirm that you have read and are agreeing to our Privacy Policy and Terms of Use

Discover more from Dev solutions

Subscribe now to keep reading and get access to the full archive.

Continue reading