Bridge.ReactLoader 16.0.1

There is a newer version of this package available.
See the version list below for details.
dotnet add package Bridge.ReactLoader --version 16.0.1                
NuGet\Install-Package Bridge.ReactLoader -Version 16.0.1                
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="Bridge.ReactLoader" Version="16.0.1" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add Bridge.ReactLoader --version 16.0.1                
#r "nuget: Bridge.ReactLoader, 16.0.1"                
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
// Install Bridge.ReactLoader as a Cake Addin
#addin nuget:?package=Bridge.ReactLoader&version=16.0.1

// Install Bridge.ReactLoader as a Cake Tool
#tool nuget:?package=Bridge.ReactLoader&version=16.0.1                

The Bridge.React bindings (NuGet) provide Bridge bindings to the React library but that package does not load the React library itself, it leaves that responsibility to the application that uses the Bridge.React package. Previously, the simplest way to load the React library has been to emit additional script tags in the html that renders the application but that has some problems - amongst which is the fact that it is a manual step to change from using the "Dev" version of the library (while developing the application) to using the "Production" version (for when the application is published).

This NuGet package will include the React library scripts directly to your project - adding the Dev version when the project is built using the Debug configuration and adding the Production version otherwise.

An example

To see this working, starting from a blank slate, do the following:

  1. Create a new solution that contains a single C# Class Library project called "ReactExample"
  2. Add the NuGet package "Bridge" (this configures the project to emit JavaScript and a html "scaffolding" page, using a default "bridge.json" configuration file that is added to the project)
  3. Add the NuGet package "Bridge.ReactLoader" (note that this will add a file "ReactLoader.cs" to your project - this is necessary for the package to work and to load the Dev / Production build appropriate for your project's configuration, so don't edit the file manually or delete it)
  4. Add the NuGet package "Bride.React" (which provides C# bindings to the React library)
  5. Edit the "Class1.cs" file that was created as part of the initial Class Library project so that it has the content below
  6. Build the project and go to the output folder (the default bridge.json configuration will write files to "bin/Debug/bridge" or "bin/Release/bridge") where you will see an auto-generated index.html; if you open this in the browser then you will see the "This was rendered by React!" message
using Bridge.Html5;
using Bridge.React;

namespace ReactExample
{
    public class Class1
    {
        public static void Main()
        {
            var container = Document.CreateElement("div");
            Document.Body.AppendChild(container);
            React.Render(
                DOM.Div("This was rendered by React!"),
                container
            );
        }
    }
}

If you view the source of the html file then you will see that the library files have been automatically added as script tags in the html. If you built your project in Debug configuration then the Dev version of the library will have been included, otherwise the Production version will be.

Note: The above example uses the default bridge.json configuration options, which include all of the scripts from referenced assemblies as individual script tags. If you want to use the combineScripts: true option that Bridge supports then that will work as well. In this case, the React library content will be bundled into the single JavaScript output file (only the Dev or Production library will be included - it will not include both versions, just as the approach shown above includes scripts tag for either the Dev version of the library or the Production version).

Versioning

The version of the NuGet package will be related to the version of the React library that is included, the first two values will relate to the React library version whils the last value will relate to version of this library - for example, "16.0.1" is build 1 of the NuGet package that loads React 16.0.

Product Compatible and additional computed target framework versions.
.NET Framework net40 is compatible.  net403 was computed.  net45 was computed.  net451 was computed.  net452 was computed.  net46 was computed.  net461 was computed.  net462 was computed.  net463 was computed.  net47 was computed.  net471 was computed.  net472 was computed.  net48 was computed.  net481 was computed. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages

This package is not used by any NuGet packages.

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last updated
16.4.2 1,362 6/19/2018
16.4.1 1,018 6/8/2018
16.0.1 1,108 10/20/2017