main.js
Tüm sayfalara (RequireJS yolunda) özel bir dosya yüklemek için bu iyi bir yoldur:
1) Yarat main.js
main.js
Tema klasörü içinde oluştur
<theme_dir>/web/js/main.js
bu içeriğe sahip:
define([
"jquery"
],
function($) {
"use strict";
// Here your custom code...
console.log('Hola');
});
Kısacası : Başlangıçta bağımlılıkları ilan ediyoruz, örn "jquery"
. Fonksiyonun bağımlılığını fonksiyonun parametresi olarak kullanmak için, örneğin fonksiyonun parametresi olarak tanımlarız "jquery" --> $
. Tüm özel kodlarımızı içine koyarız function($) { ... }
.
2) main.js
Bir requirejs-config.js
dosya ile ilan et
requirejs-config.js
Tema klasörü içinde bir dosya oluşturun :
<theme_dir>/requirejs-config.js
bu içeriğe sahip:
var config = {
// When load 'requirejs' always load the following files also
deps: [
"js/main"
]
};
"js/main"
bizim özel yoludur main.js
. ".Js" uzantısı gerekli değildir.
Bizim requirejs-config.js
diğer birleştirilir requirejs-config.js
Magento tanımladı.
RequireJS dosyamızı main.js
her sayfaya yükleyerek bağımlılıkları çözer ve dosyaları zaman uyumsuz bir şekilde yükler.
İsteğe bağlı: Üçüncü taraf kitaplığı dahil
Üçüncü taraf kütüphanelerini dahil etmenin yolu budur.
1) Kütüphaneyi içine ekle web/js
:
<theme_dir>/web/js/vendor/jquery/slick.min.js
2)requirejs-config.js
Bu içeriği aç ve ekle:
var config = {
deps: [
"js/main"
],
// Paths defines associations from library name (used to include the library,
// for example when using "define") and the library file path.
paths: {
'slick': 'js/vendor/jquery/slick.min',
},
// Shim: when you're loading your dependencies, requirejs loads them all
// concurrently. You need to set up a shim to tell requirejs that the library
// (e.g. a jQuery plugin) depends on another already being loaded (e.g. depends
// on jQuery).
// Exports: if the library is not AMD aware, you need to tell requirejs what
// to look for so it knows the script has loaded correctly. You can do this with an
// "exports" entry in your shim. The value must be a variable defined within
// the library.
shim: {
'slick': {
deps: ['jquery'],
exports: 'jQuery.fn.slick',
}
}
};
Aslında olduğundan daha karmaşık görünüyor.
3) İçinde bağımlılığı ekleyin main.js
:
define([
'jquery',
'slick'
],
function($) {
// ...
});