This project is based on the Fable template for dotnet - see below.
From a clean checkout/clone:
.\.paket/paket.exe install
npm install
dotnet build
cd src
dotnet fable npm-start
- Open
localhost:8080
Clean with git clean -fdx
.
- dotnet SDK 2.0 or higher
- node.js 6.11 or higher
- A JS package manager: yarn or npm
npm comes bundled with node.js, but we recommend to use at least npm 5. If you have npm installed, you can upgrade it by running
npm install -g npm
.
Although is not a Fable requirement, on macOS and Linux you'll need Mono for other F# tooling like Paket or editor support.
In a terminal, run dotnet new -i Fable.Template
to install or update the template to the latest version.
In a terminal, run dotnet new fable
to create a project in the current directory. Type dotnet new fable -n MyApp
instead to create a subfolder named MyApp
and put the new project there.
The project will have the name of the directory. You may get some issues if the directory name contains some special characters like hyphens
In the commands below, npm is the tool of choice. If you want to use yarn, just replace
npm
byyarn
in the commands.
- Install JS dependencies:
npm install
- If this fails, and you're behind a firewall; try
npm config set strict-ssl false
- If this fails, and you're behind a firewall; try
- Move to
src
folder:cd src
- Install F# dependencies:
dotnet restore
- If this fails with the error
Could not create SSL/TLS secure channel.
, and you're on Windows; try to add this to your registry:[HKLM\SOFTWARE\Microsoft\.NETFramework\v4.0.30319] "SchUseStrongCrypto"=DWORD:1
[HKLM\SOFTWARE\WOW6432Node\Microsoft\.NETFramework\v4.0.30319] "SchUseStrongCrypto"=DWORD:1
- Note that these keys might disable all non-strong cryptos for all .net applications on your machine, which might not be what you want.
- If this fails with the error
- Start Fable daemon and Webpack dev server:
dotnet fable npm-start
- In your browser, open: http://localhost:8080/
dotnet fable npm-start
(oryarn-start
) is used to start the Fable daemon and run a script in package.json concurrently. It's a shortcut ofyarn-run [SCRIPT_NAME]
, e.g.dotnet fable yarn-run start
.
If you are using VS Code + Ionide, you can also use the key combination: Ctrl+Shift+B (Cmd+Shift+B on macOS) instead of typing the dotnet fable npm-start
command. This also has the advantage that Fable-specific errors will be highlighted in the editor along with other F# errors.
Any modification you do to the F# code will be reflected in the web page after saving. When you want to output the JS code to disk, run dotnet fable npm-build
and you'll get a minified JS bundle in the public
folder.
This template uses babel-preset-env to output JS code whose syntax is compatible with a wide range of browsers. Currently it's set to support browsers with at least 1% of market share. To change this (for example, if you don't need to support IE), replace this line with a query understood by browserl.ist.
To replace objects and APIs that may be missing in old browsers, the index.html
file submits a request to cdn.polyfill.io that tailors the polyfill according to the user's browser.
Paket is the package manager used for F# dependencies. It doesn't need a global installation, the binary is included in the .paket
folder. Other Paket related files are:
- paket.dependencies: contains all the dependencies in the repository.
- paket.references: there should be one such a file next to each
.fsproj
file. - paket.lock: automatically generated, but should be committed to source control, see why.
- Nuget.Config: prevents conflicts with Paket in machines with some Nuget configuration.
Paket dependencies will be installed in the
packages
directory. See Paket website for more info.
- package.json: contains the JS dependencies together with other info, like development scripts.
- yarn.lock: is the lock file created by yarn.
- package-lock.json: is the lock file understood by npm 5, if you use it instead of yarn.
JS dependencies will be installed in
node_modules
. See yarn and/or npm websites for more info.
Webpack is a bundler, which links different JS sources into a single file making deployment much easier. It also offers other features, like a static dev server that can automatically refresh the browser upon changes in your code or a minifier for production release. Fable interacts with Webpack through the fable-loader
.
- webpack.config.js: is the configuration file for Webpack. It allows you to set many things: like the path of the bundle, the port for the development server or Babel options. See Webpack website for more info.
Make sure to resolve all the paths as well as Babel options to make sure all the files referenced by Fable will be found by Babel/Webpack.
The template only contains two F# source files: the project (.fsproj) and a source file (.fs) in src
folder.
Check more Fable samples, use another template like Fable.Template.Elmish.React
or SAFE.Template
, and check the awesome-fable for a curated list of resources provided by the community.