¿Hay alguna diferencia entre extender un tema usando _module.less
y _extend.less
? ¿Y cuál es la mejor práctica al extender un módulo / tema?
Mi primer pensamiento fue que es mejor usarlo _module.less
al diseñar un nuevo módulo y _extend.less
al extender un módulo. Pero Luma usa _module.less
cuando extiende el tema en blanco para que la teoría se haya ido por la ventana.
La única diferencia que puedo ver entre ellos es que _module.less
se importa antes de la biblioteca receptiva y _theme.less
dónde _extend.less
se importa después de ellos.
Este es el orden en que se importan vendor/magento/theme-frontend-blank/web/css/styles-l.less
//
// Blank theme desktop styles
// _____________________________________________
// These desktop styles are added to mobile
//
// Global lib + theme styles
// ---------------------------------------------
@import '_styles.less';
@import (reference) 'source/_extends.less';
//
// Magento Import instructions
// ---------------------------------------------
//@magento_import 'source/_module.less'; // Theme modules
//@magento_import 'source/_widgets.less'; // Theme widgets
//
// Media queries collector
// ---------------------------------------------
@import 'source/lib/_responsive.less';
@media-target: 'desktop'; // Sets target device for this file
@media-common: false; // Sets not to output common styles
//
// Global variables override
// ---------------------------------------------
@import 'source/_theme.less';
//
// Extend for minor customisation
// ---------------------------------------------
//@magento_import 'source/_extend.less';