Ini adalah kelas JS yang saya buat beberapa waktu lalu yang bisa menggunakan javascript untuk mendeteksi viewports, belum pernah melalui pengujian yang ketat tetapi berfungsi.
function ResJS(){
this.min = 0;
this.max = 0;
this.config = config;
this.width = function(){
return jQuery(window).width();
}
this.breakpoint = function(min,max){
this.min = min;
this.max = max;
this.outside = false;
this.inside = false;
this.triggeredOut = false;
this.triggeredIn = false;
this.enter = function(callback){
var context = this;
jQuery(window).on('resize',function(){
if(context.min<context.width()&&context.max>context.width()){
if(!context.triggeredIn){
jQuery(document).ready(function(){callback(context.min,context.max)});
context.inside = true; //browser width has entered breakpoint
context.outside = false; //browser has left another breakpoint
context.triggeredIn = true; //triggered event for breakpoint
context.triggeredOut = false; //be ready to trigger leave event
}
}else{
context.inside = false; //browser width is not within breakpoint
context.outside = true; //brower width is outside of breakpoint
}
});
if(context.min<context.width()&&context.max>context.width()){
jQuery(document).ready(function(){callback(context.min,context.max)});
context.inside = true;
context.outside = false;
context.triggeredIn = true;
context.triggeredOut = false;
}else{
context.inside = false;
context.outside = true;
context.triggeredOut = true;
context.triggeredIn = false;
}
return this;
}
this.leave = function(callback){
var context = this;
jQuery(window).on('resize',function(){
if(context.outside&&!context.triggeredOut){
jQuery(document).ready(function(){callback(context.min,context.max)});
context.triggeredIn = false;
context.triggeredOut = true;
}
});
return this;
}
return this;
}
return this;
}
Pada dasarnya Anda menggunakannya seperti ini
ResJS()
.breakpoint(0,600)
.enter(function(min,max){
console.log(min,max,'enter');
})
.leave(function(min,max){
console.log(min,max,'leave');
});
Breakpoint memiliki parameter min / max untuk lebar, kemudian fungsi berantai untuk memasukkannya dan pergi, dengan panggilan balik untuk menjalankan beberapa kode JS.
Saya tidak bisa menjelaskan secara terperinci bagaimana cara kerjanya, seperti yang saya lakukan dulu tapi Anda bebas menggunakannya jika itu akan membantu. Ini dapat digunakan untuk memuat modul melalui ajax berdasarkan pada viewport. Saya percaya com_ajax joomla dapat digunakan dengan ini untuk membuat beberapa fitur yang sangat keren.