-->
Get started with ASP.NET Core MVC and Visual Studio for Mac. 8/23/2017; 2 minutes to read Contributors. In this article. By Rick Anderson. This tutorial teaches you the basics of building an ASP.NET Core MVC web app using Visual Studio for Mac. This tutorial teaches ASP.NET Core MVC web development with controllers and views. In this video tutorial, I will show you the step by step process of Creating an Asp.Net Core 2.1 Application on Mac Operating System. Our Blog: www.techhowdy.com.
By Rick Anderson
- HtmlHelper - Editor. We have seen different HtmlHelper methods used to generated different html elements in the previous sections. ASP.NET MVC also includes a method that generates html input elements based on the datatype.
- I am using the latest release of RadEditor on a DNN 4.8.0 site. My client is a Mac OSX user (with Firefox). He is having huge problems getting reliable service from the editor.
- WeBuilder is a lightweight yet very powerful code editor for web developers. WeBuilder supports HTML, CSS, JavaScript, PHP, ASP, SSI, Ruby, Perl and many more web programming languages.
This is the first tutorial of a series that teaches the basics of building an ASP.NET Core Razor Pages web app.
For a more advanced introduction aimed at developers who are familiar with controllers and views, see Introduction to Razor Pages.
At the end of the series, you'll have an app that manages a database of movies.
View or download sample code (how to download).
In this tutorial, you:
- Create a Razor Pages web app.
- Run the app.
- Examine the project files.
At the end of this tutorial, you'll have a working Razor Pages web app that you'll build on in later tutorials.
Prerequisites
- Visual Studio 2019 with the ASP.NET and web development workload
The Visual Studio Code instructions use the .NET Core CLI for ASP.NET Core development functions such as project creation. You can follow these instructions on any platform (macOS, Linux, or Windows) and with any code editor. Minor changes may be required if you use something other than Visual Studio Code.
Create a Razor Pages web app
From the Visual Studio File menu, select New > Project.
Create a new ASP.NET Core Web Application and select Next.
Name the project RazorPagesMovie. It's important to name the project RazorPagesMovie so the namespaces will match when you copy and paste code.
Select ASP.NET Core 3.0 in the dropdown, Web Application, and then select Create.
The following starter project is created:
Open the integrated terminal.
Change to the directory (
cd
) which will contain the project.Run the following commands:
- The
dotnet new
command creates a new Razor Pages project in the RazorPagesMovie folder. - The
code
command opens the RazorPagesMovie folder in the current instance of Visual Studio Code.
- The
After the status bar's OmniSharp flame icon turns green, a dialog asks Required assets to build and debug are missing from 'RazorPagesMovie'. Add them? Select Yes.
A .vscode directory, containing launch.json and tasks.json files, is added to the project's root directory.
- Select File > New Solution.
Select .NET Core > App > Web Application > Next.
In the Configure your new ASP.NET Core Web API dialog, set the Target Framework to .NET Core 3.0.
Name the project RazorPagesMovie, and then select Create.
Open the project
From Visual Studio, select File > Open, and then select the RazorPagesMovie.csproj file.
Run the app
Press Ctrl+F5 to run without the debugger.
Visual Studio displays the following dialog:
Select Yes if you trust the IIS Express SSL certificate.
The following dialog is displayed:
Select Yes if you agree to trust the development certificate.
See Trust the ASP.NET Core HTTPS development certificate for more information.
Visual Studio starts IIS Express and runs the app. The address bar shows
localhost:port#
and not something likeexample.com
. That's becauselocalhost
is the standard hostname for the local computer. Localhost only serves web requests from the local computer. When Visual Studio creates a web project, a random port is used for the web server.
Trust the HTTPS development certificate by running the following command:
The preceding command doesn't work on Linux. See your Linux distribution's documentation for trusting a certificate.
The preceding command displays the following dialog:
Select Yes if you agree to trust the development certificate.
See Trust the ASP.NET Core HTTPS development certificate for more information.
Press Ctrl-F5 to run without the debugger.
Visual Studio Code starts Kestrel, launches a browser, and navigates to
http://localhost:5001
. The address bar showslocalhost:port#
and not something likeexample.com
. That's becauselocalhost
is the standard hostname for local computer. Localhost only serves web requests from the local computer.
Trust the HTTPS development certificate by running the following command:
The preceding command displays the following output:
Enter the admin username and password if prompted. The certificate will now be installed and trusted.
See Trust the ASP.NET Core HTTPS development certificate for more information.
Press Alt-Cmd-Enter to run without the debugger. Alternatively, navigate to the menu bar and go to Run>Start Without Debugging.
Visual Studio starts Kestrel, launches a browser, and navigates to
http://localhost:5001
.
Examine the project files
Here's an overview of the main project folders and files that you'll work with in later tutorials.
Pages folder
Contains Razor pages and supporting files. Each Razor page is a pair of files:
- A .cshtml file that contains HTML markup with C# code using Razor syntax.
- A .cshtml.cs file that contains C# code that handles page events.
Supporting files have names that begin with an underscore. For example, the _Layout.cshtml file configures UI elements common to all pages. This file sets up the navigation menu at the top of the page and the copyright notice at the bottom of the page. For more information, see Layout in ASP.NET Core.
wwwroot folder
Contains static files, such as HTML files, JavaScript files, and CSS files. For more information, see Static files in ASP.NET Core.
appSettings.json
Contains configuration data, such as connection strings. For more information, see Configuration in ASP.NET Core.
Program.cs
Contains the entry point for the program. For more information, see .NET Generic Host.
Startup.cs
Contains code that configures app behavior. For more information, see App startup in ASP.NET Core.
Next steps
Advance to the next tutorial in the series:
This is the first tutorial of a series. The series teaches the basics of building an ASP.NET Core Razor Pages web app.
For a more advanced introduction aimed at developers who are familiar with controllers and views, see Introduction to Razor Pages.
At the end of the series, you'll have an app that manages a database of movies.
View or download sample code (how to download).
In this tutorial, you:
- Create a Razor Pages web app.
- Run the app.
- Examine the project files.
At the end of this tutorial, you'll have a working Razor Pages web app that you'll build on in later tutorials.
Prerequisites
- Visual Studio 2019 with the ASP.NET and web development workload
Warning
If you use Visual Studio 2017, see dotnet/sdk issue #3124 for information about .NET Core SDK versions that don't work with Visual Studio.
The Visual Studio Code instructions use the .NET Core CLI for ASP.NET Core development functions such as project creation. You can follow these instructions on any platform (macOS, Linux, or Windows) and with any code editor. Minor changes may be required if you use something other than Visual Studio Code.
Create a Razor Pages web app
From the Visual Studio File menu, select New > Project.
Create a new ASP.NET Core Web Application and select Next.
Name the project RazorPagesMovie. It's important to name the project RazorPagesMovie so the namespaces will match when you copy and paste code.
Select ASP.NET Core 2.2 in the dropdown, Web Application, and then select Create.
The following starter project is created:
Open the integrated terminal.
Change to the directory (
cd
) which will contain the project.Run the following commands:
- The
dotnet new
command creates a new Razor Pages project in the RazorPagesMovie folder. - The
code
command opens the RazorPagesMovie folder in the current instance of Visual Studio Code.
- The
After the status bar's OmniSharp flame icon turns green, a dialog asks Required assets to build and debug are missing from 'RazorPagesMovie'. Add them? Select Yes.
A .vscode directory, containing launch.json and tasks.json files, is added to the project's root directory.
From a terminal, run the following command:
The preceding commands use the .NET Core CLI to create a Razor Pages project.
Open the project
From Visual Studio, select File > Open, and then select the RazorPagesMovie.csproj file.
Run the app
Press Ctrl+F5 to run without the debugger.
Visual Studio displays the following dialog:
Select Yes if you trust the IIS Express SSL certificate.
The following dialog is displayed:
Select Yes if you agree to trust the development certificate.
See Trust the ASP.NET Core HTTPS development certificate for more information.
Visual Studio starts IIS Express and runs the app. The address bar shows
localhost:port#
and not something likeexample.com
. That's becauselocalhost
is the standard hostname for the local computer. Localhost only serves web requests from the local computer. When Visual Studio creates a web project, a random port is used for the web server.On the app's home page, select Accept to consent to tracking.
This app doesn't track personal information, but the project template includes the consent feature in case you need it to comply with the European Union's General Data Protection Regulation (GDPR).
The following image shows the app after you give consent to tracking:
Trust the HTTPS development certificate by running the following command:
The preceding command doesn't work on Linux. See your Linux distribution's documentation for trusting a certificate.
The preceding command displays the following dialog:
Select Yes if you agree to trust the development certificate.
See Trust the ASP.NET Core HTTPS development certificate for more information.
Press Ctrl-F5 to run without the debugger.
Visual Studio Code starts Kestrel, launches a browser, and navigates to
http://localhost:5001
. The address bar showslocalhost:port#
and not something likeexample.com
. That's becauselocalhost
is the standard hostname for local computer. Localhost only serves web requests from the local computer.On the app's home page, select Accept to consent to tracking.
This app doesn't track personal information, but the project template includes the consent feature in case you need it to comply with the European Union's General Data Protection Regulation (GDPR).
The following image shows the app after you give consent to tracking:
Free Asp Editor
Trust the HTTPS development certificate by running the following command:
The preceding command displays the following output:
Enter the admin username and password if prompted. The certificate will now be installed and trusted.
See Trust the ASP.NET Core HTTPS development certificate for more information.
Press Cmd-Opt-F5 to run without the debugger.
Visual Studio starts Kestrel, launches a browser, and navigates to
http://localhost:5001
.On the app's home page, select Accept to consent to tracking.
This app doesn't track personal information, but the project template includes the consent feature in case you need it to comply with the European Union's General Data Protection Regulation (GDPR).
The following image shows the app after you give consent to tracking:
Examine the project files
Here's an overview of the main project folders and files that you'll work with in later tutorials.
Pages folder
Contains Razor pages and supporting files. Each Razor page is a pair of files:
- A .cshtml file that contains HTML markup with C# code using Razor syntax.
- A .cshtml.cs file that contains C# code that handles page events.
Supporting files have names that begin with an underscore. For example, the _Layout.cshtml file configures UI elements common to all pages. This file sets up the navigation menu at the top of the page and the copyright notice at the bottom of the page. For more information, see Layout in ASP.NET Core.
wwwroot folder
Contains static files, such as HTML files, JavaScript files, and CSS files. For more information, see Static files in ASP.NET Core.
appSettings.json
Contains configuration data, such as connection strings. For more information, see Configuration in ASP.NET Core.
Program.cs
Contains the entry point for the program. For more information, see .NET Generic Host.
Startup.cs
Contains code that configures app behavior, such as whether it requires consent for cookies. For more information, see App startup in ASP.NET Core.
Additional resources
Next steps
Advance to the next tutorial in the series:
We have evaluated over 20 free HTML editors for Macintosh against over 40 different criteria relevant to professional web designers and developers. The following applications are the best free HTML editors for Macintosh, both WYSIWYG and text editors, rated from best to worst. Each editor listed will have a score, percentage, and a link to more information.
Best Value: Komodo Edit
What We Like
Text Editor For Mac
Lots of add-ons available.
Built-in FTP client.
Auto-complete and syntax checking features.
What We Don't Like
Slow to load.
Feels cluttered.
Difficult to install color schemes.
Komodo Edit is hands down the best free XML editor available. It includes a lot of great features for HTML and CSS development. Plus, if that isn't enough, you can get extensions for it to add on languages or other helpful features (like special characters).
Komodo Edit is not the best HTML editor out there, but it is great for the price, especially if you build in XML. I use Komodo Edit every day for my work in XML, and I use it a lot for basic HTML editing as well. This is one editor I'd be lost without.
There are two versions of Komodo: Komodo Edit and Komodo IDE.
Best for JavaScript Developers: Aptana Studio
What We Like
Integrated debugger.
Build-in Code Assist feature for tags.
Built-in terminal emulator.
What We Don't Like
No longer in development.
Minimal support for PHP.
Some dependencies.
Aptana Studio offers an interesting take on website development. Instead of focusing on HTML, Aptana focuses on the JavaScript and other elements that allow you to create rich internet applications.
One thing I really like is the outline view that makes it really easy to visualize the document object model (DOM). This makes for easier CSS and JavaScript development.
If you are a developer creating web applications, Aptana Studio is a good choice.
A Full Featured Java IDE: NetBeans
What We Like
Version 9.0 released by Apache after acquisition.
Supports the Jigsaw Module system.
Supports Java Shell, new in JDK 9.
What We Don't Like
Needs high-memory computer to run quickly.
Not many plug-ins.
Auto-completion is buggy.
NetBeans IDE is a Java IDE that can help you build robust web applications. Like most IDEs, it has a steep learning curve because they don’t often work in the same way that web editors do. But once you get used to it you’ll be hooked.
One nice feature is the version control included in the IDE which is really useful for people working in large development environments. If you write Java and web pages this is a great tool.
Best for LAMP Developers: Bluefish
What We Like
Auto-completion and auto-tag closing.
Powerful search and replace.
Quick to start and load files.
What We Don't Like
Not for novice programmers.
User interface looks intimidating.
Too many tabs and toolbars.
Bluefish is a full-featured web editor for Linux. There are also native executables for Windows and Macintosh. There is code-sensitive spell check, autocomplete of many different languages (HTML, PHP, CSS, etc.), snippets, project management, and auto-save.
It is primarily a code editor, not specifically a web editor. This means that it has a lot of flexibility for web developers writing in more than just HTML, but if you’re a designer by nature you might not like it as much.
A Powerful Multi-Language IDE: Eclipse
What We Like
Robust debugging and profiling profile.
Code-completion feature.
Fast deployment and implementation.
What We Don't Like
Slow when working with large files.
Not recommended for large businesses.
Steep learning curve for novice programmers.
Eclipse is a complex, Open Source development environment that is perfect for people who do a lot of coding on a variety of platforms and with different languages.
Eclipse is structured as plug-ins, so if you need to edit something just find the appropriate plug-in and go.
If you are creating complex web applications, Eclipse has a lot of features to help make your application easier to build. There are Java, JavaScript, and PHP plugins, as well as a plugin for mobile developers.
A Swiss Army Knife IDE from Mozilla: SeaMonkey
What We Like
Tabs for WISIWYG editing, HTML tags, HTML code, and browser views.
Suitable for building simple, basic websites.
What We Don't Like
Composer element no longer being maintained.
Generates HTML 4.01 Transitional code.
SeaMonkey is the Mozilla project all-in-one internet application suite. It includes a web browser, email and newsgroup client, IRC chat client, and Composer, the web page editor.
Free Video Editor For Mac
One of the nice things about using SeaMonkey is that the browser is built-in, so testing is a breeze. Plus it's a free WYSIWYG editor with an embedded FTP client to publish your web pages.
A Basic HTML Writer: Amaya
What We Like
Useful for up to HTML 4.01.
Supports SVG and MathML.
What We Don't Like
Video Editor For Mac
Last updated in 2012.
No longer in development.
Amaya is the World Wide Web Consortium (W3C) web editor and web browser. It validates the HTML as you build your page and displays your Web documents in a tree structure, which is useful for learning to understand the DOM.
Amaya has a lot of features that most web designers won’t ever use, but if you want to be certain that your pages follow the W3C standards, this is a great editor to use.
Straightforward and Stable: BBEdit 12
What We Like
Supports HTML5.
Opens large files.
Great customer support.
Rock-solid software.
What We Don't Like
Advanced features require paid version after 30-day free trial.
Must search menus for features and options.
BBEdit is a paid program that has a set of free capabilities (the same capabilities that the now-defunct TextWranger had. While Bare Bones Software, the makers of BBEdit do offer a paid version, you may find the free version does everything you need. You can review a feature comparison here.
Note
If you're using TextWrangler, it is not compatible with macOS 10.13 (High Sierra). However, the free (and paid) version of BBEdit is.