Aquà se puede encontrar la información oficial del assetpipeline
Introducción
Todo lo que aprenderás sobre Ruby on Rails
¿Qué es Ruby on Rails y por qué usarlo?
Entorno de desarollo
Entorno de desarrollo de Ruby on Rails
Instalación de Ruby, RoR en Linux
Instalación de Ruby, RoR en Mac y Windows
Nuestra primera aplicación
Entender la web con rieles
Primero pasos con Ruby on Rails
Entender el enrutamiento básico
Manipular el patrón MVC
Los secretos de Rails
Assets y Layouts
Agregar el primer conjunto de scaffolds
Cómo funcionan las migraciones
Optimiza tu código con HAML
Agiliza la construcción de formularios con Simple Form
Soporte de varios idiomas para tu aplicación
Debugging: detecta los errores en tu código
Proyecto del curso: primeros pasos
¿Qué vamos a desarrollar?
Diseñando el modelo de datos
Construye los primeros scaffolds del proyecto
Internacionalizando los modelos
Agregando validaciones al modelo
Proyecto del curso: usuarios
Añadiendo el concepto de usuario
Asignando un propietario a la tarea
Añadiendo participantes a la tarea
Creando formularios anidados
Interactuando con Cocoon para anidar formularios
CanCan: ¿puedes hacerlo?
Proyecto del curso: interacciones
Callbacks en Rails
Añadiendo datos semilla
Enviando e-mails a los participantes
Añandiendo notas a la tarea
Añadiendo notas con AJAX
Embelleciendo nuestra aplicación
Cierre
Desplegando a Heroku
Conclusiones del curso
No tienes acceso a esta clase
¡Continúa aprendiendo! Únete y comienza a potenciar tu carrera
Johan Tique
Aportes 14
Preguntas 2
Aquà se puede encontrar la información oficial del assetpipeline
en rails 7 no hay o no existe ya webpacker
Hola, soy nuevo por aquÃ! QuerÃa decir que llevo unos 4 meses aprendiendo Rails por mi cuenta, todo a través de contenido en Inglés, y puedo decir dos cosas:
Por último… He venido para quedarme!
Un saludo a todos
Lo maravilloso de Rails es que aplica muy bien el principio de DRY. Los parciales permiten hacer mas rapido las paginas y no caer en repeticiones. Es muy limpio en ese sentido.
Son insumos que las respuestas HTML (y otras) necesitan para operar funcional y estéticamente de forma correcta en el cliente. Archivos CSS, JS, imágenes, fuentes, etc.
Cargar estos assets en una aplicación web puede llegar a ser un problema si no se manejan de forma correcta.
Se necesita un sistema de optimización, para que no tarde tanto el cargar los assets, también utilizar sistemas de caching para tener cierta información precargada, otra técnica es la ofuscación, para comprimir y cifrar los assets y por último sistemas de seguridad. Todo esto se puede gestionar desde Rails.
El sistema de assets en Rails se base en el Asset Pipeline
El Asset Pipeline se puede pensar como una banda que va llevando a los assets por ciertas fases para llegar al paquete final que se enviará a la web.
En esta etapa se transforman los archivos a los formatos que soporta la web, es decir. Por ejemplo, si se trabaja con SASS estos archivos pasarán por un transformador para convertirlos en CSS. Esto con todos los dialectos o meta lenguajes con los que se este trabajando
Lo que sucede aquà es que, por ejemplo, todos los archivos CSS se unan en un solo archivo y esto permite que solo se haga una petición para enviar todos los estilos de la aplicación.
Lo que el compresor es minificar los archivos que obtuvo del Concatenator para que sean lo más ligeros posible.
El fingerprinter le da un ID único al paquete para indicarle al sistema de caching las versiones de assets y asà sepa cuando es necesario reemplazar la información en caché.
Por lo general, las vistas de las aplicaciones web están divididas en secciones, como una barra de navegación, la sección del contenido principal y el footer, esto es un layout.
El Asset Pipeline se enlaza al layout al principio, en algo llamado Sporckets manifest. Aquà se referencia la estructura del Asset Pipeline y se empiezan a agrupar los assets necesarios para esa página en especÃfico.
Si la página se vuelve muy compleja se puede dividir en parciales para que no se tan complicado manejarla.
Con ayuda de el método yield, proporcionado por Rails, se manejará el contenido principal de las plantillas, para que solo este cambie y el resto de la página siga como en la plantilla.
Webpacker, recientemente añadido a Rails, es un componente que utiliza internamente Webpack. Con el propósito de tener un desarrollo de aplicaciones tanto tradicional como moderno.
Asà como para gestionar las librerÃas de Ruby se utiliza el Gemfile, para el JS de la aplicación se utiliza YARN. Con YARN se gestionarán todas las librerÃas de JavaScript, asumiendo que los archivos JS también se pueden ver como assets.
ASSETS
Insumos para que la página tenga mejor interacción visual. Un asset puede ser reglas de estilo (CSS), Scripts de JS, imágenes, etc.
Requieren:
Todo esto viene incluido en el sistema de Rails. Se basa en un componente denomidado Asset Pipeline.
Asset Pipeline
Atraviesa ciertas fases, cada fase es un estado del asset hasta llegar al producto final.
LAYOUTS
Layout es el que dice la posición de los elementos del HTML. Antes de comenzar este proceso realiza un otro proceso llamado Sprockets manifest. De esta forma, usando un comando de Rails, podemos referenciar toda la estructura del Asset Pipeline y permite consolidar los assets de esa página especÃfica.
En caso de ser una página muy compleja, es posible utilizar parciales. Los parciales extraen pequeños pedazos de código de la página y se pasan a otro archivo. Refactorizando y simplificando la página.
WEBPACK
Rails permite las arquitecturas basadas en JS. Esto usa Webpacker que utiliza el componente Webpack. Esto permite la opción entre un desarrollo de web moderno o tradicional.
Yarn
Yarn es el gemfile de webpacker. Es el gestor de paquetes para gestionar librerias JS.
Se aceptan correcciones ☹
Optimización: para que los assets no tomen tanto tiempo a la hora de ser cargados en la pagina web.
Caching: Evidenciar patrones de pre carga, donde no vas a tener que pedir siempre la misma información.
Ofuscacion: cargar un sistema en donde sea seguros los assets y se pueda comprimir.
Seguridad: utilizar fingerprints que permite acceder a los assets evitando ambiguedades entre ellos.
excelente
genial que potencien el front embebido…
Los assets de caching para guardar los datos o fuentes que se repiten para la carga mas rapida
waaaao rails+yarn+webpacker
Assets insumos, como css,js,imgy fonts para las vistas de la aplicacion
muy poderoso
Genial!
¿Quieres ver más aportes, preguntas y respuestas de la comunidad?