我需要为手机加载不同的 CSS 样式表,而不是为平板电脑加载不同的 CSS 样式表。我过去使用以下解决方案:
<meta name="viewport" content="width=device-width, initial-scale=1">
<meta name="viewport" content="width=480">
<link rel="stylesheet" media="only screen and (max-width: 480px)"href="mobile.css" />
<link rel="stylesheet" media="only screen and (min-width: 481px)" href="desktop.css" />
或者:
@media only screen and (max-width: 480px) {
}
但两者都基于屏幕分辨率。现在大部分手机都使用了更高的分辨率,所以它不会像我想要的那样工作,原因如下:平板电脑也会受到这部分的影响:
<meta name="viewport" content="width=480">
我希望平板电脑像台式机/笔记本电脑一样工作。
另外,我试图这样做:
var IS_IPHONE = navigator.userAgent.match(/iPhone/i) != null;
var IS_ANDROID = navigator.userAgent.match(/Android/i) != null;
if(IS_IPHONE) ({
url: href,
dataType: 'css',
success: function(){
$('<link rel="stylesheet" type="text/css" href="'+css/iphone.css+'" />').appendTo("head");
}
});
if(IS_ANDROID) ({
url: href,
dataType: 'css',
success: function(){
$('<link rel="stylesheet" type="text/css" href="'+css/android.css+'" />').appendTo("head");
}
});
但是现在有这么多不同的手机,我无法搜索所有可能的设备并添加一次。此外,安卓现在也是平板电脑。
是否有任何通用代码可以检测智能手机(不是平板电脑,只是手机)?我想它不能基于媒体查询。
我试图根据当前帖子找到解决方案,但我的问题没有明确的答案,所以我在这里发布了。
谢谢