移动端自适应

1 .js代码如何检测当前运行环境,移动或者pc,node或者浏览器

 var browser = {
            versions: function() {
                var u = navigator.userAgent, app = navigator.appVersion;
                return {     //移动终端浏览器版本信息
                    trident: u.indexOf('Trident') > -1, //IE内核
                    presto: u.indexOf('Presto') > -1, //opera内核
                    webKit: u.indexOf('AppleWebKit') > -1, //苹果、谷歌内核
                    gecko: u.indexOf('Gecko') > -1 && u.indexOf('KHTML') == -1, //火狐内核
                    mobile: !!u.match(/AppleWebKit.*Mobile.*/), //是否为移动终端
                    ios: !!u.match(/\(i[^;]+;( U;)? CPU.+Mac OS X/), //ios终端
                    android: u.indexOf('Android') > -1 || u.indexOf('Linux') > -1, //android终端或uc浏览器
//还可能会有手机的品牌
                    iPhone: u.indexOf('iPhone') > -1, //是否为iPhone或者QQHD浏览器
                    iPad: u.indexOf('iPad') > -1, //是否iPad
                    webApp: u.indexOf('Safari') == -1 //是否web应该程序,没有头部与底部
                };
            } (),
            language: (navigator.browserLanguage || navigator.language).toLowerCase()
        }
        if (browser.versions.mobile) {//判断是否是移动设备打开。browser代码在下面
            /* var ua = navigator.userAgent.toLowerCase();//获取判断用的对象
            if (ua.match(/MicroMessenger/i) == "micromessenger") {
            //在微信中打开
            setInterval(WeixinJSBridge.call('closeWindow'),2000);
            }
            if (ua.match(/WeiBo/i) == "weibo") {
            //在新浪微博客户端打开
            }
            if (ua.match(/QQ/i) == "qq") {
            //在QQ空间打开
            }
            if (browser.versions.ios) {
            //是否在IOS浏览器打开
            } 
            if(browser.versions.android){
            //是否在安卓浏览器打开
            }*/
            window.location.href = "http://m.baidu.com/";
        }
        /*else {
        //否则就是PC浏览器打开
        window.close();
        }

2 .Echarts中移动端自适应的操作方式

option={
  baseOption:{
  //基础的文件
},
media:[
 {
    query:{
    width:'',
    height:'',
    maxAspectRatio:1
    //满足这个宽,满足这个高,满足这个宽高比,就用下面这个options
//还支持maxWidth,minWidth等选择参数
    option:{
}
},{
  query:{}
//和上一个是一样的,但是最后还有一个默认的样式,即所有都匹配不到的时候使用这个样式。
}
}
]
}

3 .当有多个query同时被满足的时候,会先mergeOption,定义在后优先级更高
4 .默认query,如果某项的query值为0,那么就是默认值,当所有的规则都不满足的时候,采纳这个option.
5 .

你可能感兴趣的:(移动端自适应)