Pues eso… si aún trabajas con proyectos que utilizan ASP.NET con Webforms, es decir páginas ASPX, debes tener Visual Studio 2019 instalado y con las opciones adecuadas, ya que Visual Studio 2022 solo utiliza ASP:NET Core y no podrás crear «amigablemente» nuevas páginas ASPX en el proyecto, entre otras cosas porque no están en el SDK de .NET, si no en el de .NET Framework.
Si no tienes Visual Studio 2019 instalado, puedes entrar en esta página para descargarlo.
Si ya lo tienes instalado, asegúrate que tienes estas opciones seleccionadas: (ver figura 1)
De esta forma podrás crear nuevas páginas ASPX (WebForms) o cualquier otro tipo que puedas usar con ASP.NET para .NET Framework.
Espero que te haya sido de utilidad.
Ya sabes, si quieres, puedes hacer un donativo «al blog del Guille» 😉
Pues eso… aunque he leído por ahí que no es conveniente detectar si se está navegando en un dispositivo móvil… eso era porque lo hacía con código duro (hard-code) es decir, detectar según el valor devuelto por userAgent de window.navigator, que sí, que puede producir resultados no deseados… pero… si usas Request.Browser.IsMobileDevice la cosa cambia.
Y hacer esa comprobación es bien simple. ¿Dónde hacerla? En cualquier parte del código «script» de tu página ASP.NET (de .NET Framework), ya sea que estés usando Visual Basic o C# (o incluso otros lenguajes que soporten las páginas web asp.net de .net framework).
Un par de ejemplos, por favor
Esta es una página .aspx con código para C#:
<%@PageLanguage="C#"AutoEventWireup="true" %>
<scriptrunat="server">protectedvoid Page_Load(object sender, EventArgs e)
{
if (Request.Browser.IsMobileDevice)
{
LabelDesktop.Visible = false;
LabelMobile.Visible = true;
}
else
{
LabelDesktop.Visible = true;
LabelMobile.Visible = false;
}
}
</script><!DOCTYPEhtml><htmlxmlns="http://www.w3.org/1999/xhtml"><headrunat="server"><title></title></head><bodystyle="font-family:Consolas"><formid="form1"runat="server"><div><asp:Labelrunat="server"ID="LabelMobile"Visible="false"Font-Size="xx-Large"Font-Bold="true"Text="Estas viendo esto en el navegador de un dispositivo móvil."/><asp:Labelrunat="server"ID="LabelDesktop"Visible="false"Font-Size="xx-Large"Font-Bold="true"Text="Estas viendo esto en el navegador de escritorio."/></div></form></body></html>
Esta es una página .aspx con código para Visual Basic:
<%@PageLanguage="VB"AutoEventWireup="true" %>
<scriptrunat="server">ProtectedSub Page_Load(sender AsObject, e AsEventArgs)
If Request.Browser.IsMobileDevice Then
LabelDesktop.Visible = False
LabelMobile.Visible = TrueElse
LabelDesktop.Visible = True
LabelMobile.Visible = FalseEndIfEndSub</script><!DOCTYPEhtml><htmlxmlns="http://www.w3.org/1999/xhtml"><headrunat="server"><title></title></head><bodystyle="font-family:Consolas"><formid="form1"runat="server"><div><asp:Labelrunat="server"ID="LabelMobile"Visible="false"Font-Size="xx-Large"Font-Bold="true"Text="Estas viendo esto en el navegador de un dispositivo móvil."/><asp:Labelrunat="server"ID="LabelDesktop"Visible="false"Font-Size="xx-Large"Font-Bold="true"Text="Estas viendo esto en el navegador de escritorio."/></div></form></body></html>
Nota: Puedes tener las dos páginas en una misma aplicación o proyecto WEB de Visual Studio sin necesidad de hacer nada especial, solo tener las páginas en un sitio que acepte .NET Framework.
A tener en cuenta
Si muestras la páginas en un dispositivo móvil, es posible que el navegador te permita ver la página como «escritorio», en ese caso, el valor que devuelve es escritorio, no que es móvil. En las siguientes capturas tienes la demostración. En esas capturas estoy usando el Edge para Android en un Google Pixel 4a.
En la figura 1 estoy mostrando la página versión de Visual Basic en el móvil, que si quieres la puedes probar usando el enlace mostrado (está alojada en mi sitio: elguille.info/WebFormVB.aspx).
En la figura 2 te muestro la versión para C# antes de cambiarla a modo escritorio. También puedes probarla usando este enlace en mi sitio: elguille.info/WebFormCS.aspx.
Nota: También puedes probarlo en el navegador de escritorio usando las herramientas de desarrollador, que en Edge y Chrome se pueden acceder usando Ctrl+Shift+I. Y desde esas herramientas puedes indicar que se muestre como si fuese en un móvil (ver la figura 4).
Pues eso… el otro día estaba escribiendo código para un nuevo sitio web de un colega (ConservasYoga.com.es) y me decidí a hacerlo en C# , por aquello de que creía que ya no existen plantillas (o eso creo ) en Visual Studio 2019 para ASP.NET con Visual Basic, pero sí existen, de las que no existen es para usar ASP.NET Core.
La cuestión es que quería acceder a ciertas propiedades (y/o métodos) de la master page y lo hice (o lo intenté) tal como lo hago con Visual Basic, es decir, usando Master.Propiedad, pero nada… daba error… después de muchas pruebas lo conseguí… algo rebuscado, pero… probando, probando… lo pude encontrar, y es que en C# para acceder a las cosas definidas en una página maestra hay que usar el nombre de la página maestra (en minúsculas) seguida de un guón bajo y la palabra master (también en minúsculas), es decir, si la página maestra se llama Site.master para acceder al código desde C# hay que usarlo de esta forma: site_master.
Un ejemplo de sitio usando Master Page en VB y C#
Para este ejemplo he optado por seleccionar un sitio en blanco: ASP.NET Empty Web Site (ver figura 1), ya que si se elige el tipo ASP.NET Web Forms Site te añade un montón de código y página, etc., que… en los hosting de ASP.NET que hay por esta zona no funcionan… y si intento que sea de ASP.NET Core ya ni te digo, ninguna de las empresas de hosting con las que he probado (Axarnet, IONOS, acens) lo soportan, incluso una de ellas me dijo que como es código abierto por eso no lo soportan… pero sí venden servidores con Linux, WordPress, PHP… que… ¡lo mismo no son de código abierto! 😉
En fin…
Cuando trabajo con sitios de ASP.NET no me gusta usar el code behind, si no que prefiero que cada página tenga su código, de esa forma no es necesario compilar la aplicación, si no que se usa el código directamente en el sitio hospedado y ya está… el ASP.NET de IIS se encarga de compilar las páginas y el código a usar. Y lo mejor es que si haces cambios, solo tienes que subir la página o el fichero de código modificado y ya está… ¡a compilarlo tocan! pero… ¡que lo compile otro! 😉
En el segundo tipo de proyecto todo lo que añade el Visual Studio usa el code behind, mientras que en el proyecto vacío, cuando añadas una nueva página (maestra o normal) puedes indicar que no se incluya el código de forma separada (que es lo que viene a significar el code behind o separación entre el diseño y el código).
Si elegimos añadir una nueva página con el código incrustado en la propia página tendremos que hacer algo como lo mostrado en la figura 2.
En ese caso, se indica también seleccionar una página maestra para esa página aspx.
Y si decidimos que el código esté separado lo haremos como se muestra en la figura 3.
Es decir, quitamos la marca de la casilla Place code in separate file.
Al añadir una página de esa forma tendremos esto en la página:
Donde CodeFile indica qué página es la que tiene el código y el Inherits es el nombre de la clase.
Si esto lo has hecho por error… puedes arreglarlo. ¿Cómo? Simplemente quitando todo lo que se indica en CodeFile y en Inherits y poniendo el código aparte, tal como te muestro a continuación:
Nota: Por cierto, esa página la he añadido al proyecto de C#, pero está usando el código de VB, y es porque yo, por error, he seleccionado una página de Visual Basic (tal como ves en la figura 3). Pero en el código mostrado lo he cambiado a C#.
Decir o aclarar que en un sitio web hecho con ASP.NET para .NET Framework podemos usar tanto código de VB como de C#, aunque no revueltos.
En este sitio que he creado, en el proyecto de C# uso una página con código de VB y otras dos con el código de C#.
En la página maestre he definido una propiedad con el título de la aplicación. En C# quedaría de esta forma:
En la de Visual Basic, esa misma propiedad la definimos como te muestro a continuación:
<scriptrunat="server">PublicSharedProperty AppName AsString = "Web Site Master VB"</script>
Como es una propiedad compartida, en C# se utiliza static y en VB se usa Shared.
Y para usarla desde C# lo haríamos de esta forma, por ejemplo para poner el título de la página 2:
<asp:ContentID="Content2"ContentPlaceHolderID="ContentPlaceHolder1"Runat="Server"><h2>Prueba2 en C# para <%=masterpage_master.AppName %> </h2></asp:Content>
Como dije al principio, en VB podemos usar Master para acceder al código de la página maestra, en C# no sepuede. Lo que también se puede en VB es usar la clase de la página maestra, es decir, tal como se hace en C#. Decirte que esto último hará que en VB no te muestre un warning que sí muestra cuando se accede a la página maestra usando Master (ver la figura 4).
Nota: No sé porque ahora me muestra ese warning, ya que siempre lo he usado así (con Master.Propiedad) y nunca había salido esa advertencia, pero bueno… si queremos compatibilidad entre los dos lenguajes, podemos hacerlo usando el nombre de la clase.
Resumiendo el acceso a las páginas maestras desde código
Mejor usar el nombre de la clase, tanto en C# (que es la única forma de ahcerlo, al menos que yo sepa) como en VB.
Te iba a comentar que, aparte de lo que ya hemos visto, desde un sitio web de asp.net con .NET Framework se puede usar tanto código de VB y de C# en conjunto, solo hay que poner dicho código en carpetas diferentes e indicarlo en el fichero Web.Config.
Usar código de VB y C# en un mismo sitio de ASP.NET Framework
Crea la carpeta de código App_Code, decide qué lenguaje será el que use las clases puestas en esa carpeta (normalmente el lenguaje con el que has creado el proyecto), crea una nueva carpeta (dentro de App_Code) para poner las clases del otro lenguaje.
Por ejemplo, si queremos que en la carpeta App_Code estén las clases de VB y en la carpeta c-sharp (App_Code\c-sharp), pondremos esto en el fichero web.config:
Este código estará dentro de la rama: <configuration><system.web>.
Para acceder a las clases o el código se hace de la forma habitual, en este ejemplo, he definido una propiedad estática/compartida para que se pueda acceder desde el código ASP.
Hay que tener en cuenta que C# distingue entre mayúsculas y minúculas, mientras que a VB le da igual como la escribamos.
<p>Usando el código definido en la carpeta <b>App_Code</b></p>
<p>Acceso al código de C# (class1.Nombre): <% =Class1.Nombre %> </p>
<p>Acceso al código de VB (class2.Nombre): <% =Class2.Nombre %> </p>
<p>En C# hay que usar correctamente el nombre: Class1 y Class2 (no class1/class2 como en VB).</p>
Y esto es todo… este es el código en GitHub por si le quieres echar un vistazo.
Cambios en el código de C# para que compile con C# 5.0
Al limpiar el proyecto de los «packages» que añade el Visual Studio, empiezan los errores, uno de ellos es que C# 5.0 no permite asignar valores a las auto-propiedades, por tanto, el código mostrado antes hay que sustituirlo por este otro:
El de la clase Class1.cs: (tanto en el proyecto de VB como en el de C#)
publicstaticstring Nombre
{
get { return"¡Hola Mundo de C#!"; }
}
El de la página maestra:
<scriptrunat="server">publicstaticstring AppName
{
get {return"Web Site Master C#"; }
}
</script>
El código de VB no hay que modificarlo, se ve que el compilador usado reconoce la autodefinición de propiedades con asignación de valores.