zoukankan      html  css  js  c++  java
  • SmartPhone手机网站的制作

    刚开始努力有点偏,看到响应式网站去了,其实主要是要用JQuery Mobile

    做一个像应用的网站。

    JQuery Mobile的教程 http://www.hongkiat.com/blog/build-websites-apps-jquery-mobile-custom-themes/

    介绍了怎么自定义颜色主题等等。

    利用了遍历的JS框架,就必须忍受默认的CSS带来的束缚。

    布局上也不像平时想浮动就浮动。基本上所有元素的属性都是既定的,为了避免冲突,需要用固有布局来改。

    比如横向两栏的布局,父容器class ui-grid-a,子容器 ui-block-a,uiblock-b;

    垂直列表用data-role="listview"。

    最后针对不同设备,还是要用到媒体查询。不过针对手机就不需要像响应式网站做的分辨率那么多种了。

    响应式的做法:

    首先,CSS和一般的RESET有些不同:

    度娘找 响应式布局就会发现百科里面有这些附加设置:
    html {
    -webkit-text-size-adjust: none;
    }
    /* 设置HTML5元素为块 */
    article, aside, details, figcaption, figure, footer, header, hgroup, menu, nav, section {
    display: block;
    }
    /* 设置图片视频等自适应调整 */
    img {
    max-width: 100%; height: auto; width: auto9; /* ie8 */}
    .video embed, .video object, .video iframe {
    width: 100%;
    height: auto;
    }
    最后要注意的是在页面的头部<head></head>之间加上下面这句∶
    <meta name=“viewport” content=“width=device-width; initial-scale=1.0”>
    meta viewport这个属性是在移动设备上设置原始大小显示和是否缩放的声明。
    参数设置∶
    width – viewport的宽度
    height – viewport的高度
    initial-scale – 初始的缩放比例
    minimum-scale – 允许用户缩放到的最小比例
    maximum-scale – 允许用户缩放到的最大比例
    user-scalable – 用户是否可以手动缩放

    另外,在阮一峰老师博客看到图片的详细设置:

     img { max- 100%;}与上面相同

    这行代码对于大多数嵌入网页的视频也有效,所以可以写成:

      img, object { max- 100%;}

    老版本的IE不支持max-width,所以只好写成:

      img { 100%; }

    此外,windows平台缩放图片时,可能出现图像失真现象。这时,可以尝试使用IE的专有命令

      img { -ms-interpolation-mode: bicubic; }  //这是上面没有提到的。

    把CSS都设置好了以后,对应一些不同尺寸的屏幕,使用Media Query编写CSS。

    常见的几个尺寸有:

    @media screen and (max- 1140px) and (min- 1024px){#social-box{display:inline}#social-box-vert,#wallpaper{display:none}}
    @media screen and (max- 1023px) and (min- 768px){.side-home{margin-left:14px;padding-right:0px}#home-right{border-right:none;border-left:none;margin-left:14px;padding-right:0;padding-left:0px;300px}}
    @media screen and (max- 767px) and (min- 600px){#home-right{border-right:none;padding-right:none}}
    @media screen and (max- 599px) and (min- 480px){#home-right{border-right:none;margin-left:0;padding-right:0;420px;border-left:none;padding-left:0px}}
    @media screen and (max- 479px){.side-home{margin-left:0;margin-top:20px;padding-right:0px}#home-right{margin-bottom:0px;border-right:none;margin-left:0;padding-right:0;300px;border-left:none;padding-left:0px}}

    @media screen and (min- 1000px){#gameoftheday{display:none}}

    实际做smartphone的时候分得很细,可是320这一档适用的机型是在太多了,iphone5,4,3还有安卓,屏幕表现还不一定一样!

    /*pad*/
    @media screen and (min- 769px){}
    /*horizontal iphone5 568x320*/
    @media screen and (max- 768px) and (min- 481px){}
    /*horizontal iphone4 480x320,large android*/
    @media screen and (max- 480px) and (min- 380px){}
    /*=====vertical iphone5 320x568,vertical iphone4 320x480 ,Android=====*/
    @media screen and (max- 379px) and (min- 320px){}
    /*-----small Android-----*/
    @media screen and (max- 319px) and (min- 240px){}
    /*further small*/
    @media screen and (max- 239px){}

    媒体查询也可以用高度,不过不常见,手册在:http://www.w3chtml.com/css3/properties/madia-queries/height.html

    具体使用比较有讲究,来自ADOBE的文章http://www.adobe.com/cn/devnet/dreamweaver/articles/introducing-media-queries.html

    ( width , height , device-width , device-height , 和 orientation ) 是最有用的。您可以为大部分功能添加 min- 和 max- 作为前缀,以表示最小和最大值,比如 min-width 和max-width 。表 1 中的“最大值/最小值”列表是哪些功能可通过此方式修改。

    width、device-width和viewport

    媒体查询的一个最容易混淆的方面或许就是width和height与添加了前缀device-的类似值之间的区别。对于桌面和平板计算机,它们之间的区别很容易理解:width 和 height指浏览器视区的尺寸,而device-width和device-height指显示器的尺寸。不是每个人都会全屏运行他或她的浏览器,所以width 和 height是您需要使用的度量方法。

    移动浏览器将填满可用的屏幕,所以您可能期望width和device-width是相同的。不幸的是,并不总是这样。大多数智能电话(包括Android、iPhone和Windows Phone 7)将width设置为大约1,000像素宽的标称视区(在iPhone和iPod touch中,它为980像素;Windows Phone 7使用1024像素)。图4展示了iPod touch通常如何显示前面插图中的示例页面。
    即使附加到页面上的样式表使用媒体查询,依据min-width 和 max-width 的值来提供不同样式,iPod touch会忽略这些样式并显示桌面版本,因为它的视区被视为980像素宽。

    更让人混淆的是,iPhone、iPod touch和iPad在计算宽度时不会考虑方向,而其他设备会。

    幸运的是,这种混淆情形有一个简单的解决方案。苹果公司设计了一个新的<meta>标记,它已被其他移动设备制造商广泛采用,已合并到可能会被万维网联盟(W3C)批准的规范中。要为支持媒体查询的所有设备提供公平的机会,只需向每个网页的<head>添加以下这行代码:

    <meta name="viewport" content="width=device-width, initial-scale=1">

    这告诉移动设备,将视区视为具有设备的物理宽度相同的宽度。而且,它还告诉iPhone、iPod touch和iPad在计算宽度时考虑方向。这样,您可以在媒体查询中安全地使用width,因为您知道它的用途与您所想的相同。

    注意:许多移动设备(最显著的就是iPhone 4和iPad 2)拥有高分辨率的显示屏,具有比桌面或平板显示器高得多的像素密度。这不会影响您在CSS中计算像素大小的方式。CSS规范要求,如果输出设备的像素密度与典型计算机显示器的像素密度差别巨大,浏览器应该重新调节像素值。一些开发人员现在将像素度量方法称为CSS像素。

    另外有个使IE6,7,8兼容媒体查询CSS的JS  http://code.google.com/p/css3-mediaqueries-js/

    <!--[if IE]>
    <script src="js/css3-mediaqueries.js" type="text/javascript"></script>
    <![endif]-->

    各种表单组件可以用 http://jquerymobile.com/

    除了用CSS设置图片大小,还可以用JS:

    var imgSizer = {
        Config : {
            imgCache : []
            ,spacer : "/path/to/your/spacer.gif"
        }
    
        ,collate : function(aScope) {
            var isOldIE = (document.all && !window.opera && !window.XDomainRequest) ? 1 : 0;
            if (isOldIE && document.getElementsByTagName) {
                var c = imgSizer;
                var imgCache = c.Config.imgCache;
    
                var images = (aScope && aScope.length) ? aScope : document.getElementsByTagName("img");
                for (var i = 0; i < images.length; i++) {
                    images[i].origWidth = images[i].offsetWidth;
                    images[i].origHeight = images[i].offsetHeight;
    
                    imgCache.push(images[i]);
                    c.ieAlpha(images[i]);
                    images[i].style.width = "100%";
                }
    
                if (imgCache.length) {
                    c.resize(function() {
                        for (var i = 0; i < imgCache.length; i++) {
                            var ratio = (imgCache[i].offsetWidth / imgCache[i].origWidth);
                            imgCache[i].style.height = (imgCache[i].origHeight * ratio) + "px";
                        }
                    });
                }
            }
        }
    
        ,ieAlpha : function(img) {
            var c = imgSizer;
            if (img.oldSrc) {
                img.src = img.oldSrc;
            }
            var src = img.src;
            img.style.width = img.offsetWidth + "px";
            img.style.height = img.offsetHeight + "px";
            img.style.filter = "progid:DXImageTransform.Microsoft.AlphaImageLoader(src='" + src + "', sizingMethod='scale')"
            img.oldSrc = src;
            img.src = c.Config.spacer;
        }
    
        // Ghettomodified version of Simon Willison's addLoadEvent() -- http://simonwillison.net/2004/May/26/addLoadEvent/
        ,resize : function(func) {
            var oldonresize = window.onresize;
            if (typeof window.onresize != 'function') {
                window.onresize = func;
            } else {
                window.onresize = function() {
                    if (oldonresize) {
                        oldonresize();
                    }
                    func();
                }
            }
        }
    }
    imgSizer.js
    addLoadEvent(function() {
        var imgs = document.getElementById("content").getElementsByTagName("img");
        imgSizer.collate(imgs);
      });

     基本上也是IE7需要用:

    <!--[if lte IE 7]><script type="text/javascript" src="site/imgSizer.js"></script>
    <script type="text/javascript">
    window.onload = function() {
        imgSizer.collate();
    }
    </script><![endif]-->

    暂时资料准备到这里,具体做了以后再总结一个完备的CSS reset,这是一开始做打算用的版本: 

    /* reset */
    article,aside,details,figcaption,figure,footer,header,hgroup,nav,section{display:block}
    audio[controls],canvas,video{display:inline-block;*display:inline;*zoom:1}
    html{font-size:100%;overflow-y:scroll;-webkit-overflow-scrolling:touch;-webkit-tap-highlight-color:rgba(0,0,0,0);-webkit-text-size-adjust:none;-ms-text-size-adjust:100%;}
    body,div,dl,dt,dd,ul,ol,li,h1,h2,h3,h4,h5,h6,pre,form,fieldset,input,textarea,p,blockquote,th,td { margin:0px; padding:0px; font-family:'微软雅黑', Meiryo, "MS Pゴシック", Hiragino Kaku Gothic Pro, sans-serif;}
    table { border-collapse:collapse; border-spacing:0;}
    fieldset,img { border:0px; margin:0; padding:0; vertical-align:bottom;}
    img,object{max-width:100%; height:auto; width:auto9; /* ie8 */ *width: 100%;/* ie6 */-ms-interpolation-mode: bicubic;}
    .video embed, .video object, .video iframe {width:100%; height:auto;}
    address,caption,cite,code,dfn,em,strong,th,var { font-style:normal; font-weight:normal;}
    ol, ul, li, dl, dt, dd { list-style-type:none outside none; _list-style-type:none; }
    caption,th {text-align:left;}
    h1,h2,h3,h4,h5,h6 {font-size:100%;font-weight:normal;}
    q:before,q:after {content:'';}
    abbr,acronym { border:0;}
    a{ text-decoration:none; cursor:pointer;}

    除了麻烦的媒体查询,就注意一下宽度尽量用百分比,字号用em,坚持浮动布局就可以了。

    附上公司国庆休假安排:

    中秋节

    19号至21号休息,22号上班

    国庆节

    29号上班,1号开始至7号休息,10月12号上班

  • 相关阅读:
    第一部分 android display(sufaceflinger & overlay)
    UML类图关系大全
    第二部分 MediaPlayer的接口与架构
    Climbing Stairs
    Add Binary
    Plus One
    Unique Paths
    Length of Last Word
    Count and Say
    Valid Sudoku
  • 原文地址:https://www.cnblogs.com/haimingpro/p/3309875.html
Copyright © 2011-2022 走看看