StackShareStackShare
Follow on
StackShare

Discover and share technology stacks from companies around the world.

Follow on

© 2025 StackShare. All rights reserved.

Product

  • Stacks
  • Tools
  • Feed

Company

  • About
  • Contact

Legal

  • Privacy Policy
  • Terms of Service
  1. Stackups
  2. DevOps
  3. Build Automation
  4. Package Managers
  5. Flow Type vs PureScript

Flow Type vs PureScript

OverviewDecisionsComparisonAlternatives

Overview

PureScript
PureScript
Stacks88
Followers86
Votes18
GitHub Stars8.8K
Forks569
Flow (JS)
Flow (JS)
Stacks145
Followers75
Votes0
GitHub Stars22.2K
Forks1.9K

Flow (JS) vs PureScript: What are the differences?

Developers describe Flow (JS) as "Flow is a static type checker for Javascript (by Facebook)". Flow is a static type checker for Javascript created by Facebook. On the other hand, PureScript is detailed as "A strongly-typed language that compiles to Javascript". A small strongly typed programming language with expressive types that compiles to JavaScript, written in and inspired by Haskell.

Flow (JS) and PureScript are primarily classified as "Static Type Checkers" and "Templating Languages & Extensions" tools respectively.

Flow (JS) and PureScript are both open source tools. It seems that Flow (JS) with 19.7K GitHub stars and 1.68K forks on GitHub has more adoption than PureScript with 5.86K GitHub stars and 427 GitHub forks.

Share your Stack

Help developers discover the tools you use. Get visibility for your team's tech choices and contribute to the community's knowledge.

View Docs
CLI (Node.js)
or
Manual

Advice on PureScript, Flow (JS)

StackShare
StackShare

Aug 13, 2019

Needs adviceonTypeScriptTypeScriptCoffeeScriptCoffeeScriptJavaScriptJavaScript

From a StackShare community member: "We are looking to rewrite our outdated front-end with TypeScript. Right now we have a mix of CoffeeScript and vanilla JavaScript. I have read that adopting TypeScript can help enforce better code quality, and best practices. I also heard good things about Flow (JS). Which one would you recommend and why?"

405k views405k
Comments
Oleksandr
Oleksandr

Senior Software Engineer at joyn

Oct 21, 2019

Decided

Initially making a decision to use Flow vs Typescript we decided to go with flow as we wanted our code to run in a way we wrote it, because when using Flow types are simply removed from the code without modifying the code itself. Sadly, the type system of Flow was in some cases very hard to understand and declare the types correctly, especially in cases when the structure is very dynamic (e.g. object keys and values are created dynamically). Another reason was bad integration with IDE and frequent crashes which made DX very poor. Therefore, we made another evaluation of Typescript and decided to move towards it. As our code base was pretty big when we decided to migrate to TS we couldn't just stop and re-write everything, that's why we started writing new modules in Typescript as well as transforming old components. To make that possible we had to configure Webpack loader to support simultaneous bundling of Flow&JS and Typescript. After around 2 months of the transformation we have around 40% of code being written in Typescript and we are more than happy with integration TS has with IDE, as well as ease of declaring types for dynamic modules and functions.

149k views149k
Comments
Vladyslav
Vladyslav

Sr. Directory of Technology at Shelf

Oct 25, 2019

Decided

As our codebase grew in size, we were looking for ways to improve code quality. We chose TypeScript over Flow due to its rapid industry adoption and overall tools support.

We noticed how different open-source projects were migrating from Flow to TypeScript. Most notably, it was Jest, even though Jest and Flow were both developed by Facebook. See this HN thread if you want to dive into an interesting discussion around this move.

Additionally, at the beginning of 2019, both Babel and ESLint enabled seamless TypeScript support, which allowed easy migration path in a backward-compatible way.

155k views155k
Comments

Detailed Comparison

PureScript
PureScript
Flow (JS)
Flow (JS)

A small strongly typed programming language with expressive types that compiles to JavaScript, written in and inspired by Haskell.

Flow is a static type checker for Javascript created by Facebook.

-
Type Inference; Easy Integration; Realtime Feedback
Statistics
GitHub Stars
8.8K
GitHub Stars
22.2K
GitHub Forks
569
GitHub Forks
1.9K
Stacks
88
Stacks
145
Followers
86
Followers
75
Votes
18
Votes
0
Pros & Cons
Pros
  • 6
    Purely functional
  • 4
    Great FFI to JavaScript
  • 2
    Alternate backends
  • 2
    The best type system
  • 1
    More Haskell-ish than Haskell
Cons
  • 1
    No JSX/Template
  • 1
    Have Some Bugs
  • 1
    Not so fancy error reporting
No community feedback yet

What are some alternatives to PureScript, Flow (JS)?

Meteor

Meteor

A Meteor application is a mix of JavaScript that runs inside a client web browser, JavaScript that runs on the Meteor server inside a Node.js container, and all the supporting HTML fragments, CSS rules, and static assets.

CoffeeScript

CoffeeScript

It adds syntactic sugar inspired by Ruby, Python and Haskell in an effort to enhance JavaScript's brevity and readability. Specific additional features include list comprehension and de-structuring assignment.

Bower

Bower

Bower is a package manager for the web. It offers a generic, unopinionated solution to the problem of front-end package management, while exposing the package dependency model via an API that can be consumed by a more opinionated build stack. There are no system wide dependencies, no dependencies are shared between different apps, and the dependency tree is flat.

TypeScript

TypeScript

TypeScript is a language for application-scale JavaScript development. It's a typed superset of JavaScript that compiles to plain JavaScript.

Pug

Pug

This project was formerly known as "Jade." Pug is a high performance template engine heavily influenced by Haml and implemented with JavaScript for Node.js and browsers.

Elm

Elm

Writing HTML apps is super easy with elm-lang/html. Not only does it render extremely fast, it also quietly guides you towards well-architected code.

Handlebars.js

Handlebars.js

Handlebars.js is an extension to the Mustache templating language created by Chris Wanstrath. Handlebars.js and Mustache are both logicless templating languages that keep the view and the code separated like we all know they should be.

Julia

Julia

Julia is a high-level, high-performance dynamic programming language for technical computing, with syntax that is familiar to users of other technical computing environments. It provides a sophisticated compiler, distributed parallel execution, numerical accuracy, and an extensive mathematical function library.

Racket

Racket

It is a general-purpose, multi-paradigm programming language based on the Scheme dialect of Lisp. It is designed to be a platform for programming language design and implementation. It is also used for scripting, computer science education, and research.

Mustache

Mustache

Mustache is a logic-less template syntax. It can be used for HTML, config files, source code - anything. It works by expanding tags in a template using values provided in a hash or object. We call it "logic-less" because there are no if statements, else clauses, or for loops. Instead there are only tags. Some tags are replaced with a value, some nothing, and others a series of values.

Related Comparisons

GitHub
Bitbucket

Bitbucket vs GitHub vs GitLab

GitHub
Bitbucket

AWS CodeCommit vs Bitbucket vs GitHub

Kubernetes
Rancher

Docker Swarm vs Kubernetes vs Rancher

gulp
Grunt

Grunt vs Webpack vs gulp

Graphite
Kibana

Grafana vs Graphite vs Kibana