Dota Heroes
Hello, this is a demo project to show an application and example of using an external API. In this case,
OpenDota API.
This project is made using Svelte, See more at
Svelte.dev.
Alchemist
![Alchemist](https://cdn.cloudflare.steamstatic.com/apps/dota2/images/dota_react/heroes/alchemist.png)
Primary Attr: STR
Roles: Carry, Support, Durable, Disabler, Initiator, Nuker
Ancient Apparition
![Ancient Apparition](https://cdn.cloudflare.steamstatic.com/apps/dota2/images/dota_react/heroes/ancient_apparition.png)
Primary Attr: INT
Roles: Support, Disabler, Nuker
Anti-Mage
![Anti-Mage](https://cdn.cloudflare.steamstatic.com/apps/dota2/images/dota_react/heroes/antimage.png)
Primary Attr: AGI
Roles: Carry, Escape, Nuker
Arc Warden
![Arc Warden](https://cdn.cloudflare.steamstatic.com/apps/dota2/images/dota_react/heroes/arc_warden.png)
Primary Attr: AGI
Roles: Carry, Escape, Nuker
Axe
![Axe](https://cdn.cloudflare.steamstatic.com/apps/dota2/images/dota_react/heroes/axe.png)
Primary Attr: STR
Roles: Initiator, Durable, Disabler, Carry
Bloodseeker
![Bloodseeker](https://cdn.cloudflare.steamstatic.com/apps/dota2/images/dota_react/heroes/bloodseeker.png)
Primary Attr: AGI
Roles: Carry, Disabler, Nuker, Initiator
Bounty Hunter
![Bounty Hunter](https://cdn.cloudflare.steamstatic.com/apps/dota2/images/dota_react/heroes/bounty_hunter.png)
Primary Attr: AGI
Roles: Escape, Nuker
Bristleback
![Bristleback](https://cdn.cloudflare.steamstatic.com/apps/dota2/images/dota_react/heroes/bristleback.png)
Primary Attr: STR
Roles: Carry, Durable, Initiator, Nuker
Centaur Warrunner
![Centaur Warrunner](https://cdn.cloudflare.steamstatic.com/apps/dota2/images/dota_react/heroes/centaur.png)
Primary Attr: STR
Roles: Durable, Initiator, Disabler, Nuker, Escape
Chaos Knight
![Chaos Knight](https://cdn.cloudflare.steamstatic.com/apps/dota2/images/dota_react/heroes/chaos_knight.png)
Primary Attr: STR
Roles: Carry, Disabler, Durable, Pusher, Initiator
Clinkz
![Clinkz](https://cdn.cloudflare.steamstatic.com/apps/dota2/images/dota_react/heroes/clinkz.png)
Primary Attr: AGI
Roles: Carry, Escape, Pusher
Crystal Maiden
![Crystal Maiden](https://cdn.cloudflare.steamstatic.com/apps/dota2/images/dota_react/heroes/crystal_maiden.png)
Primary Attr: INT
Roles: Support, Disabler, Nuker
Dawnbreaker
![Dawnbreaker](https://cdn.cloudflare.steamstatic.com/apps/dota2/images/dota_react/heroes/dawnbreaker.png)
Primary Attr: STR
Roles: Carry, Durable
Death Prophet
![Death Prophet](https://cdn.cloudflare.steamstatic.com/apps/dota2/images/dota_react/heroes/death_prophet.png)
Primary Attr: INT
Roles: Carry, Pusher, Nuker, Disabler
Disruptor
![Disruptor](https://cdn.cloudflare.steamstatic.com/apps/dota2/images/dota_react/heroes/disruptor.png)
Primary Attr: INT
Roles: Support, Disabler, Nuker, Initiator
Doom
![Doom](https://cdn.cloudflare.steamstatic.com/apps/dota2/images/dota_react/heroes/doom_bringer.png)
Primary Attr: STR
Roles: Carry, Disabler, Initiator, Durable, Nuker
Dragon Knight
![Dragon Knight](https://cdn.cloudflare.steamstatic.com/apps/dota2/images/dota_react/heroes/dragon_knight.png)
Primary Attr: STR
Roles: Carry, Pusher, Durable, Disabler, Initiator, Nuker
Drow Ranger
![Drow Ranger](https://cdn.cloudflare.steamstatic.com/apps/dota2/images/dota_react/heroes/drow_ranger.png)
Primary Attr: AGI
Roles: Carry, Disabler, Pusher
Earth Spirit
![Earth Spirit](https://cdn.cloudflare.steamstatic.com/apps/dota2/images/dota_react/heroes/earth_spirit.png)
Primary Attr: STR
Roles: Nuker, Escape, Disabler, Initiator, Durable
Earthshaker
![Earthshaker](https://cdn.cloudflare.steamstatic.com/apps/dota2/images/dota_react/heroes/earthshaker.png)
Primary Attr: STR
Roles: Support, Initiator, Disabler, Nuker
Elder Titan
![Elder Titan](https://cdn.cloudflare.steamstatic.com/apps/dota2/images/dota_react/heroes/elder_titan.png)
Primary Attr: STR
Roles: Initiator, Disabler, Nuker, Durable
Ember Spirit
![Ember Spirit](https://cdn.cloudflare.steamstatic.com/apps/dota2/images/dota_react/heroes/ember_spirit.png)
Primary Attr: AGI
Roles: Carry, Escape, Nuker, Disabler, Initiator
Enchantress
![Enchantress](https://cdn.cloudflare.steamstatic.com/apps/dota2/images/dota_react/heroes/enchantress.png)
Primary Attr: INT
Roles: Support, Pusher, Durable, Disabler
Faceless Void
![Faceless Void](https://cdn.cloudflare.steamstatic.com/apps/dota2/images/dota_react/heroes/faceless_void.png)
Primary Attr: AGI
Roles: Carry, Initiator, Disabler, Escape, Durable
Grimstroke
![Grimstroke](https://cdn.cloudflare.steamstatic.com/apps/dota2/images/dota_react/heroes/grimstroke.png)
Primary Attr: INT
Roles: Support, Nuker, Disabler, Escape
Gyrocopter
![Gyrocopter](https://cdn.cloudflare.steamstatic.com/apps/dota2/images/dota_react/heroes/gyrocopter.png)
Primary Attr: AGI
Roles: Carry, Nuker, Disabler
Hoodwink
![Hoodwink](https://cdn.cloudflare.steamstatic.com/apps/dota2/images/dota_react/heroes/hoodwink.png)
Primary Attr: AGI
Roles: Support, Nuker, Escape, Disabler
Huskar
![Huskar](https://cdn.cloudflare.steamstatic.com/apps/dota2/images/dota_react/heroes/huskar.png)
Primary Attr: STR
Roles: Carry, Durable, Initiator
Jakiro
![Jakiro](https://cdn.cloudflare.steamstatic.com/apps/dota2/images/dota_react/heroes/jakiro.png)
Primary Attr: INT
Roles: Support, Nuker, Pusher, Disabler
Juggernaut
![Juggernaut](https://cdn.cloudflare.steamstatic.com/apps/dota2/images/dota_react/heroes/juggernaut.png)
Primary Attr: AGI
Roles: Carry, Pusher, Escape
Keeper of the Light
![Keeper of the Light](https://cdn.cloudflare.steamstatic.com/apps/dota2/images/dota_react/heroes/keeper_of_the_light.png)
Primary Attr: INT
Roles: Support, Nuker, Disabler
Kunkka
![Kunkka](https://cdn.cloudflare.steamstatic.com/apps/dota2/images/dota_react/heroes/kunkka.png)
Primary Attr: STR
Roles: Carry, Support, Disabler, Initiator, Durable, Nuker
Legion Commander
![Legion Commander](https://cdn.cloudflare.steamstatic.com/apps/dota2/images/dota_react/heroes/legion_commander.png)
Primary Attr: STR
Roles: Carry, Disabler, Initiator, Durable, Nuker
Leshrac
![Leshrac](https://cdn.cloudflare.steamstatic.com/apps/dota2/images/dota_react/heroes/leshrac.png)
Primary Attr: INT
Roles: Carry, Support, Nuker, Pusher, Disabler
Lich
![Lich](https://cdn.cloudflare.steamstatic.com/apps/dota2/images/dota_react/heroes/lich.png)
Primary Attr: INT
Roles: Support, Nuker
Lifestealer
![Lifestealer](https://cdn.cloudflare.steamstatic.com/apps/dota2/images/dota_react/heroes/life_stealer.png)
Primary Attr: STR
Roles: Carry, Durable, Escape, Disabler
Lina
![Lina](https://cdn.cloudflare.steamstatic.com/apps/dota2/images/dota_react/heroes/lina.png)
Primary Attr: INT
Roles: Support, Carry, Nuker, Disabler
Lion
![Lion](https://cdn.cloudflare.steamstatic.com/apps/dota2/images/dota_react/heroes/lion.png)
Primary Attr: INT
Roles: Support, Disabler, Nuker, Initiator
Luna
![Luna](https://cdn.cloudflare.steamstatic.com/apps/dota2/images/dota_react/heroes/luna.png)
Primary Attr: AGI
Roles: Carry, Nuker, Pusher
Mars
![Mars](https://cdn.cloudflare.steamstatic.com/apps/dota2/images/dota_react/heroes/mars.png)
Primary Attr: STR
Roles: Carry, Initiator, Disabler, Durable
Medusa
![Medusa](https://cdn.cloudflare.steamstatic.com/apps/dota2/images/dota_react/heroes/medusa.png)
Primary Attr: AGI
Roles: Carry, Disabler, Durable
Meepo
![Meepo](https://cdn.cloudflare.steamstatic.com/apps/dota2/images/dota_react/heroes/meepo.png)
Primary Attr: AGI
Roles: Carry, Escape, Nuker, Disabler, Initiator, Pusher
Monkey King
![Monkey King](https://cdn.cloudflare.steamstatic.com/apps/dota2/images/dota_react/heroes/monkey_king.png)
Primary Attr: AGI
Roles: Carry, Escape, Disabler, Initiator
Morphling
![Morphling](https://cdn.cloudflare.steamstatic.com/apps/dota2/images/dota_react/heroes/morphling.png)
Primary Attr: AGI
Roles: Carry, Escape, Durable, Nuker, Disabler
Naga Siren
![Naga Siren](https://cdn.cloudflare.steamstatic.com/apps/dota2/images/dota_react/heroes/naga_siren.png)
Primary Attr: AGI
Roles: Carry, Support, Pusher, Disabler, Initiator, Escape
Nature's Prophet
![Nature's Prophet](https://cdn.cloudflare.steamstatic.com/apps/dota2/images/dota_react/heroes/furion.png)
Primary Attr: INT
Roles: Carry, Pusher, Escape, Nuker
Necrophos
![Necrophos](https://cdn.cloudflare.steamstatic.com/apps/dota2/images/dota_react/heroes/necrolyte.png)
Primary Attr: INT
Roles: Carry, Nuker, Durable, Disabler
Night Stalker
![Night Stalker](https://cdn.cloudflare.steamstatic.com/apps/dota2/images/dota_react/heroes/night_stalker.png)
Primary Attr: STR
Roles: Carry, Initiator, Durable, Disabler, Nuker
Ogre Magi
![Ogre Magi](https://cdn.cloudflare.steamstatic.com/apps/dota2/images/dota_react/heroes/ogre_magi.png)
Primary Attr: STR
Roles: Support, Nuker, Disabler, Durable, Initiator
Omniknight
![Omniknight](https://cdn.cloudflare.steamstatic.com/apps/dota2/images/dota_react/heroes/omniknight.png)
Primary Attr: STR
Roles: Support, Durable, Nuker
Oracle
![Oracle](https://cdn.cloudflare.steamstatic.com/apps/dota2/images/dota_react/heroes/oracle.png)
Primary Attr: INT
Roles: Support, Nuker, Disabler, Escape
Outworld Devourer
![Outworld Devourer](https://cdn.cloudflare.steamstatic.com/apps/dota2/images/dota_react/heroes/obsidian_destroyer.png)
Primary Attr: INT
Roles: Carry, Nuker, Disabler
Phantom Assassin
![Phantom Assassin](https://cdn.cloudflare.steamstatic.com/apps/dota2/images/dota_react/heroes/phantom_assassin.png)
Primary Attr: AGI
Roles: Carry, Escape
Phantom Lancer
![Phantom Lancer](https://cdn.cloudflare.steamstatic.com/apps/dota2/images/dota_react/heroes/phantom_lancer.png)
Primary Attr: AGI
Roles: Carry, Escape, Pusher, Nuker
Puck
![Puck](https://cdn.cloudflare.steamstatic.com/apps/dota2/images/dota_react/heroes/puck.png)
Primary Attr: INT
Roles: Initiator, Disabler, Escape, Nuker
Pudge
![Pudge](https://cdn.cloudflare.steamstatic.com/apps/dota2/images/dota_react/heroes/pudge.png)
Primary Attr: STR
Roles: Disabler, Initiator, Durable, Nuker
Pugna
![Pugna](https://cdn.cloudflare.steamstatic.com/apps/dota2/images/dota_react/heroes/pugna.png)
Primary Attr: INT
Roles: Nuker, Pusher
Queen of Pain
![Queen of Pain](https://cdn.cloudflare.steamstatic.com/apps/dota2/images/dota_react/heroes/queenofpain.png)
Primary Attr: INT
Roles: Carry, Nuker, Escape
Razor
![Razor](https://cdn.cloudflare.steamstatic.com/apps/dota2/images/dota_react/heroes/razor.png)
Primary Attr: AGI
Roles: Carry, Durable, Nuker, Pusher
Riki
![Riki](https://cdn.cloudflare.steamstatic.com/apps/dota2/images/dota_react/heroes/riki.png)
Primary Attr: AGI
Roles: Carry, Escape, Disabler
Rubick
![Rubick](https://cdn.cloudflare.steamstatic.com/apps/dota2/images/dota_react/heroes/rubick.png)
Primary Attr: INT
Roles: Support, Disabler, Nuker
Shadow Demon
![Shadow Demon](https://cdn.cloudflare.steamstatic.com/apps/dota2/images/dota_react/heroes/shadow_demon.png)
Primary Attr: INT
Roles: Support, Disabler, Initiator, Nuker
Shadow Fiend
![Shadow Fiend](https://cdn.cloudflare.steamstatic.com/apps/dota2/images/dota_react/heroes/nevermore.png)
Primary Attr: AGI
Roles: Carry, Nuker
Shadow Shaman
![Shadow Shaman](https://cdn.cloudflare.steamstatic.com/apps/dota2/images/dota_react/heroes/shadow_shaman.png)
Primary Attr: INT
Roles: Support, Pusher, Disabler, Nuker, Initiator
Silencer
![Silencer](https://cdn.cloudflare.steamstatic.com/apps/dota2/images/dota_react/heroes/silencer.png)
Primary Attr: INT
Roles: Carry, Support, Disabler, Initiator, Nuker
Skywrath Mage
![Skywrath Mage](https://cdn.cloudflare.steamstatic.com/apps/dota2/images/dota_react/heroes/skywrath_mage.png)
Primary Attr: INT
Roles: Support, Nuker, Disabler
Slardar
![Slardar](https://cdn.cloudflare.steamstatic.com/apps/dota2/images/dota_react/heroes/slardar.png)
Primary Attr: STR
Roles: Carry, Durable, Initiator, Disabler, Escape
Slark
![Slark](https://cdn.cloudflare.steamstatic.com/apps/dota2/images/dota_react/heroes/slark.png)
Primary Attr: AGI
Roles: Carry, Escape, Disabler, Nuker
Sniper
![Sniper](https://cdn.cloudflare.steamstatic.com/apps/dota2/images/dota_react/heroes/sniper.png)
Primary Attr: AGI
Roles: Carry, Nuker
Spectre
![Spectre](https://cdn.cloudflare.steamstatic.com/apps/dota2/images/dota_react/heroes/spectre.png)
Primary Attr: AGI
Roles: Carry, Durable, Escape
Spirit Breaker
![Spirit Breaker](https://cdn.cloudflare.steamstatic.com/apps/dota2/images/dota_react/heroes/spirit_breaker.png)
Primary Attr: STR
Roles: Carry, Initiator, Disabler, Durable, Escape
Storm Spirit
![Storm Spirit](https://cdn.cloudflare.steamstatic.com/apps/dota2/images/dota_react/heroes/storm_spirit.png)
Primary Attr: INT
Roles: Carry, Escape, Nuker, Initiator, Disabler
Sven
![Sven](https://cdn.cloudflare.steamstatic.com/apps/dota2/images/dota_react/heroes/sven.png)
Primary Attr: STR
Roles: Carry, Disabler, Initiator, Durable, Nuker
Templar Assassin
![Templar Assassin](https://cdn.cloudflare.steamstatic.com/apps/dota2/images/dota_react/heroes/templar_assassin.png)
Primary Attr: AGI
Roles: Carry, Escape
Terrorblade
![Terrorblade](https://cdn.cloudflare.steamstatic.com/apps/dota2/images/dota_react/heroes/terrorblade.png)
Primary Attr: AGI
Roles: Carry, Pusher, Nuker
Tidehunter
![Tidehunter](https://cdn.cloudflare.steamstatic.com/apps/dota2/images/dota_react/heroes/tidehunter.png)
Primary Attr: STR
Roles: Initiator, Durable, Disabler, Nuker, Carry
Timbersaw
![Timbersaw](https://cdn.cloudflare.steamstatic.com/apps/dota2/images/dota_react/heroes/shredder.png)
Primary Attr: STR
Roles: Nuker, Durable, Escape
Tinker
![Tinker](https://cdn.cloudflare.steamstatic.com/apps/dota2/images/dota_react/heroes/tinker.png)
Primary Attr: INT
Roles: Carry, Nuker, Pusher
Tiny
![Tiny](https://cdn.cloudflare.steamstatic.com/apps/dota2/images/dota_react/heroes/tiny.png)
Primary Attr: STR
Roles: Carry, Nuker, Pusher, Initiator, Durable, Disabler
Treant Protector
![Treant Protector](https://cdn.cloudflare.steamstatic.com/apps/dota2/images/dota_react/heroes/treant.png)
Primary Attr: STR
Roles: Support, Initiator, Durable, Disabler, Escape
Troll Warlord
![Troll Warlord](https://cdn.cloudflare.steamstatic.com/apps/dota2/images/dota_react/heroes/troll_warlord.png)
Primary Attr: AGI
Roles: Carry, Pusher, Disabler, Durable
Tusk
![Tusk](https://cdn.cloudflare.steamstatic.com/apps/dota2/images/dota_react/heroes/tusk.png)
Primary Attr: STR
Roles: Initiator, Disabler, Nuker
Underlord
![Underlord](https://cdn.cloudflare.steamstatic.com/apps/dota2/images/dota_react/heroes/abyssal_underlord.png)
Primary Attr: STR
Roles: Support, Nuker, Disabler, Durable, Escape
Undying
![Undying](https://cdn.cloudflare.steamstatic.com/apps/dota2/images/dota_react/heroes/undying.png)
Primary Attr: STR
Roles: Support, Durable, Disabler, Nuker
Ursa
![Ursa](https://cdn.cloudflare.steamstatic.com/apps/dota2/images/dota_react/heroes/ursa.png)
Primary Attr: AGI
Roles: Carry, Durable, Disabler
Viper
![Viper](https://cdn.cloudflare.steamstatic.com/apps/dota2/images/dota_react/heroes/viper.png)
Primary Attr: AGI
Roles: Carry, Durable, Initiator, Disabler
Warlock
![Warlock](https://cdn.cloudflare.steamstatic.com/apps/dota2/images/dota_react/heroes/warlock.png)
Primary Attr: INT
Roles: Support, Initiator, Disabler
Weaver
![Weaver](https://cdn.cloudflare.steamstatic.com/apps/dota2/images/dota_react/heroes/weaver.png)
Primary Attr: AGI
Roles: Carry, Escape
Witch Doctor
![Witch Doctor](https://cdn.cloudflare.steamstatic.com/apps/dota2/images/dota_react/heroes/witch_doctor.png)
Primary Attr: INT
Roles: Support, Nuker, Disabler
Wraith King
![Wraith King](https://cdn.cloudflare.steamstatic.com/apps/dota2/images/dota_react/heroes/skeleton_king.png)
Primary Attr: STR
Roles: Carry, Support, Durable, Disabler, Initiator
Zeus
![Zeus](https://cdn.cloudflare.steamstatic.com/apps/dota2/images/dota_react/heroes/zuus.png)
Primary Attr: INT
Roles: Nuker, Carry