Как использовать javascript условно как CSS3-медиа-запросы, ориентация?
Как использовать javascript условно, как медиа-запросы CSS3, ориентация?
В качестве примера я могу написать css для конкретных
@media only screen and (width : 1024px) and (orientation : landscape) {
.selector1 { width:960px}
}
Теперь я хочу запустить только javascript, если он соответствует тем же условиям
как
@media only screen and (width : 1024px) and (orientation : landscape) {
A javascript code here
}
У меня есть внешний javascript, например http://ajax.aspnetcdn.com/ajax/jQuery/jquery-1.6.4.min.js
, и он должен выполняться только по определенному размеру экрана и ориентации
Ответы
Ответ 1
Вы можете использовать window.matchMedia():
Протестируйте медиа-запрос мобильного устройства
if (matchMedia('only screen and (max-width: 480px)').matches) {
// smartphone/iphone... maybe run some small-screen related dom scripting?
}
Тест альбомной ориентации
if (matchMedia('all and (orientation:landscape)').matches) {
// probably tablet in widescreen view
}
В настоящее время поддерживается во всех современных браузерах (подробнее)
Polyfill для старых браузеров: https://github.com/paulirish/matchMedia.js/
Ответ 2
... Я хочу запустить javascript только в том случае, если максимальная ширина браузера составляет 1900 пикселей и минимальная ширина 768
EDIT: На самом деле все было неправильно. Если вы используете мобильное устройство, используйте:
function doStuff(){
landscape = window.orientation? window.orientation=='landscape' : true;
if(landscape && window.innerWidth<1900 && window.innerWidth > 768){
//code here
}
}
window.onload=window.onresize=doStuff;
if(window.onorientationchange){
window.onorientationchange=doStuff;
}
Ответ 3
Я могу придумать быстрое решение: условно применить некоторые стили к невидимому div и проверить, применяются ли они с помощью javascript:
div#test { display: none }
@media only screen and (width : 1024px) and (orientation : landscape) {
div#test { background-color: white; }
}
if(document.getElementById('test').style.backgroundColor == 'white')
mediaSelectorIsActive();
Ответ 4
Возможно, стоит упомянуть, что есть событие orientchange, которое вы, возможно, захотите подключить так:
$('body').bind('orientationchange', function(){
// check orientation, update styles accordingly
});
Я знаю, что об этом событии, запущенном мобильным Safari, вам нужно будет проверить другие браузеры.
Ответ 5
Вместо этого вы можете переписать медиа-запрос как выражение javascript:
function sizehandler(evt) {
...
}
function orientationhandler(evt){
// For FF3.6+
if (!evt.gamma && !evt.beta) {
evt.gamma = -(evt.x * (180 / Math.PI));
evt.beta = -(evt.y * (180 / Math.PI));
}
// use evt.gamma, evt.beta, and evt.alpha
// according to dev.w3.org/geo/api/spec-source-orientation
...
}
window.addEventListener('deviceorientation', orientationhandler, false);
window.addEventListener('MozOrientation', orientationhandler, false);
window.addEventListener('load', orientationhandler, false);
window.addEventListener('resize', sizehandler, false);
window.addEventListener('load', sizehandler, false);