移动端webapp自适应实践(css雪碧图制作小工具实践)图文并茂

为什么要写这个

以前写过关于webapp自适应屏幕的文章(链接),不过写的大多数群众看不懂,所以来个图文并茂的版本。虽然只是一个简单的页面,不过在做的过程中也遇到了一些问题,也算是好事吧!

该示例github地址:https://github.com/iwangx/WebApp

访问地址:https://csssprite.herokuapp.com/

准备

psd:这个是最重要的东西,用于测量尺寸,以及切图,我是不太同意切图的工作交给ui,自己切比较好,psd的分辨率我做的是640px的宽度,当然这个psd是网上下的

css雪碧图制作工具:最新版(v4.3)能够将多张图片拼接成一张图片并且生成代码的小程序(本人自主研发)

webstorm:前端开发利器

马克曼:前端尺寸颜色测量工具

photoshop:切图利器

sass:css预编译工具

第一步、切图

我用的是photoshop切的图,切图如下:

当然可能看不太清楚,毕竟是白色的图

第二步、搭建框架

 大体结构就是这个,地址:https://github.com/iwangx/WebApp

第二部、css结构

css主要采用sass作于预编译的工具,结构如下:

reset.scss文件主要是对于元素样式的重置

app.scss文件是对单个页面样式

size.scss文件里面包含了手机端自适应1-400尺寸的变量

第二步、js结构

js中最重要的是自适应的的代码,地址:移动端自适应,zepto这些都没有引入,因为只是个简单的示例

第三步、html页面机构

页面结构如下图:

header:头部标题

nav:头部的导航

controller:中间列表

footer:底部导航

第四步、生成雪碧图

利用雪碧图生成工具:生成雪碧图,并且生成代码:

将代码copy到css目录中的app.scss目录下

当然前提是要引入size这个里面方面变量的文件,要不然$_*就没法识别而报错了

第五步、页面以及css编码

css代码:

@import "size";
//所有图片变量
@mixin sprite{background:url(../images/sprite.png) no-repeat ;background-size:$_138 $_163;}
@mixin icon_right{height:$_59;width:$_59;background-position:0 -$_75 0 -$_5;}
@mixin icon_left{height:$_59;width:$_59;background-position:0 0;}
@mixin icon_tag{height:$_44;width:$_65;background-position:0 -$_1 0 -$_119;}
@mixin icon_person{height:$_44;width:$_65;background-position:0 0 -$_66;}
@mixin icon_book{height:$_44;width:$_65;background-position:0 -$_73 0 -$_71;}
@mixin icon_more{height:$_44;width:$_65;background-position:0 -$_73 0 -$_119;}

body{background: #fbfbfb}
.sprite{@include sprite;}
.header{position: fixed;background: #dd3131;height: $_90;line-height: $_90;;width: 100%;left: 0;top: 0;font-size: $_40;color: #fff;text-align: center;
  button{position: absolute;top: $_16;border: $_2 solid #fff;border-radius: 50%;box-sizing: content-box}
}
.btn-left{@include icon_left;left: $_16;}
.btn-right{@include icon_right;right: $_16;}
.nav{display: -webkit-box;position: fixed;left: 0;top: $_90;color: #3d3d3d;font-size: $_30;width: 100%;border-bottom: $_1 solid #e7e5e6;
  a{display: block;height: $_60;line-height: $_60;text-align: center;background: #fff;-webkit-box-flex: 1;border-right: $_1 solid #e7e5e6;box-sizing: border-box;}
}
.controller{padding: $_151 0 $_100 0;}
.list{
  li{border-bottom:$_1 solid #cfcfcf }
  a{display: -webkit-box;padding: $_16;}
  img{height: $_122;width: $_122;display: block}
}
.list-right{-webkit-box-flex: 1;padding-left: $_15;
  h1{color: #555;font-size: $_24;}
  p{color: #878787;font-size: $_18;margin-top: $_15;line-height: 1.5}
}
.footer{height: $_100;position: fixed;left: 0;bottom: 0;width: 100%;display: -webkit-box;background: #4a4a4a;text-align: center;
  a{display: block;-webkit-box-flex: 1;box-sizing: border-box;padding-top: $_10;border-right: $_1 solid #fff;
    &:last-child{border-right: none}
  }
  i{display: block;margin: 0 auto}
  span{color: #fff;font-size: $_24;display: block;margin-top: $_5;}
}
.icon_book{@include icon_book}
.icon_tag{@include icon_tag}
.icon_person{@include icon_person}
.icon_more{@include icon_more}

 html代码:

<!DOCTYPE html>
<html>
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="initial-scale=0.5,minimum-scale=0.5, maximum-scale=0.5,user-scalable=no,minimal-ui">
    <meta name="author" content="wangxing">
    <meta name="screen-orientation" content="portrait">
    <meta name="x5-orientation" content="portrait">
    <meta name="format-detection" content="telephone=no">
    <title>app自适应</title>
    <link rel="stylesheet" href="/css/reset.css">
    <link rel="stylesheet" href="/css/app.css">
    <script src="/js/lib/resize.js"></script>
</head>
<body>
    <header class="header">
        <button class="sprite btn-left"></button>
        <span>远程酒业</span>
        <button class="sprite btn-right"></button>
    </header>
    <nav class="nav">
        <a href="javascript:;">资讯</a>
        <a href="javascript:;">产品</a>
        <a href="javascript:;">实战</a>
        <a href="javascript:;">讨论</a>
    </nav>
    <section class="controller">
        <ul class="list">
            <li>
                <a href="#">
                    <img src="src" alt="图片">
                    <div class="list-right">
                        <h1>酒名字</h1>
                        <p>提升白酒等传统酒类生产机械化水平成为行业未来研究工作的重点,从而促进酿酒装备与技术的快速发展……</p>
                    </div>
                </a>
            </li>
            <li>
                <a href="#">
                    <img src="src" alt="图片">
                    <div class="list-right">
                        <h1>酒名字</h1>
                        <p>提升白酒等传统酒类生产机械化水平成为行业未来研究工作的重点,从而促进酿酒装备与技术的快速发展……</p>
                    </div>
                </a>
            </li>
            <li>
                <a href="#">
                    <img src="src" alt="图片">
                    <div class="list-right">
                        <h1>酒名字</h1>
                        <p>提升白酒等传统酒类生产机械化水平成为行业未来研究工作的重点,从而促进酿酒装备与技术的快速发展……</p>
                    </div>
                </a>
            </li>
            <li>
                <a href="#">
                    <img src="src" alt="图片">
                    <div class="list-right">
                        <h1>酒名字</h1>
                        <p>提升白酒等传统酒类生产机械化水平成为行业未来研究工作的重点,从而促进酿酒装备与技术的快速发展……</p>
                    </div>
                </a>
            </li>
        </ul>
    </section>
    <footer class="footer">
        <a href="#">
            <i class="sprite icon_book"></i>
            <span>资讯</span>
        </a>
        <a href="#">
            <i class="sprite icon_tag"></i>
            <span>产品</span>
        </a>
        <a href="#">
            <i class="sprite icon_person"></i>
            <span>实战</span>
        </a>
        <a href="#">
            <i class="sprite icon_more"></i>
            <span>讨论</span>
        </a>
    </footer>
</body>
</html>

用到图片的地方,主要有两个class,一个是雪碧图的class,一个就是他本事引用的class,二者结合

大家可以看到css代码中的大小全都是$_*,也就是测量出来的大小,包括字号也是

 这样就构成了我们的webapp

iphone5上是这样

iphone6上是这样

平板上是这样

时间: 2024-09-14 23:17:50

移动端webapp自适应实践(css雪碧图制作小工具实践)图文并茂的相关文章

CSS雪碧图会占用太多浏览器内存吗?

可能是某篇微博的关系,今天有人来评论说,使用雪碧图,内存会暴涨的...这个问题讨论的也蛮多了,那,到底,使用雪碧图后,会占用很多内存吗? 实验: 下午做了个简单的实验,用99个128px*128px的png 32图片,写了三个页面来做测试: 只用img标签调用: 用css分别调用每个png图片做背景: 使用雪碧图做背景 然后分别用Chrome.IE6/7/8/9.Firefox做测试,具体的数据我这里就不详细列了,感兴趣的话可以自测一下. 结论: 在各浏览器下,三个页面占用的内存相当,只有很小的

【转】CSS雪碧图会占用太多浏览器内存吗

可能是某篇微博的关系,今天有人来评论说,使用雪碧图,内存会暴涨的...这个问题讨论的也蛮多了,那,到底,使用雪碧图后,会占用很多内存吗? 实验: 下午做了个简单的实验,用99个128px*128px的png 32图片,写了三个页面来做测试: 只用img标签调用: 用css分别调用每个png图片做背景: 使用雪碧图做背景 然后分别用Chrome.IE6/7/8/9.Firefox做测试,具体的数据我这里就不详细列了,感兴趣的话可以自测一下. 结论: 在各浏览器下,三个页面占用的内存相当,只有很小的

CSS雪碧,即CSS Sprite 简单的例子

CSS Sprite生成工具 http://pan.baidu.com/s/1gdGQwiJ 工具可将多幅图片整合一张,并生成CSS. HTML代码 <style> .img{background:url(img.png) no-repeat;} .Lighthouse{height:768px;width:1024px;background-position:0 0;} .Koala{height:768px;width:1024px;background-position:0 -768px

移动端WebApp隐藏地址栏的方法

这篇文章主要介绍了移动端WebApp隐藏地址栏的方法,本文分别给出了4种方法,适应不同情况下使用,小编推荐最后一个方法,需要的朋友可以参考下     1.很多资料说,添加以下代码,可以隐藏地址栏,但我试了很多次,貌似不成功啊.  代码如下: <meta name="apple-mobile-web-app-capable" content="yes" /> 2.我们可以通过另一种方法来隐藏地址栏.在页面加载完成之后滚动窗口,这个确实有效,唯一要注意的是页

移动端webapp开发必备知识

原文地址:http://www.qianduan.net/mobile-webapp-develop-essential-knowledge.html 转载自:移动终端开发必备知识 请尊重版权,转载请注明来源,多谢~~ 移动设备的用户越来越多,每天android手机的激活量都已经超过130万台,所以我们面向移动终端的WebAPP也开始跟进了.本文主要介绍webapp的开发与调试的相关知识和经验,以及给出几种可选的解决方案. 一.基本概念 (1) CSS pixels与device pixels

移动端WebApp开发 你需要从这几点学起

移动端WebApp开发 (学习的过程分析) Html5概述以及应用场景 手机浏览器的特点Viewpoint 视口 ,dpi, px 的区别meta 属性,缩放,拖放rem 实战,字体选择移动端事件模型响应式布局,弹性盒子模型硬件加速原理移动端性能优化点HTML5画布:canvasHTML5多媒体:video,audio

在喝雪碧之后呕吐不止,里面竟是消毒水

这瓶雪碧倒出来的液体是黄色的 中国网7月31日讯(记者 姚毅婧)本年5月28日晚,在福州某餐厅吃饭的林小姐在喝雪碧没多久之后呕吐不止,经检查后发现食道被轻微灼伤.经过医生初步诊断,林小姐喝下的竟然是含氯的消毒水,该事件曾一度被媒体"热炒",并得到中国网财经中心持续关注.近期,厦门可口可乐装瓶厂在接受中国网财经中心采访时透露,问题雪碧样品检测结果成份是次氯酸纳溶液,但是这从哪里而来,公司并未能够"追根刨底".这个公司人士还表示,基于人文关怀,公司用现金的方式为消费者早

雪碧灼伤消费者食道追踪:解决方案疑点重重

这瓶雪碧倒出来的液体是黄色的 中国网7月31日讯(记者 姚毅婧)今年5月28日晚,在福州某餐厅吃饭的林小姐在喝雪碧不久之后呕吐不止,经检查食道被轻微灼伤.经过医生初步诊断,林小姐喝下的是含氯的消毒水,该事件曾一度被媒体"热炒",并得到中国网财经中心持续关注.近日,厦门可口可乐装瓶厂在接受中国网财经中心采访时透露,问题雪碧样品检测结果成份为次氯酸纳溶液,但其从何而来,公司并未能够"追根刨底".该公司人士还表示,基于人文关怀,公司以现金的方式为消费者早日康复提供了帮助,

过期哈啤兑雪碧制假洋啤酒成本不足2元卖30元

用来勾兑假酒的雪碧勾兑后的假酒黑加工点内十分混乱 用普通的大瓶啤酒兑雪碧,分装到小瓶的百威.喜力.嘉士伯.科罗娜等高档啤酒瓶内,成本每瓶2元钱左右,可消费者在各大娱乐场所购买时,一瓶就要二三十元.29日,位于哈市道外区团结镇的这个啤酒造假黑窝点,被哈市质监.公安部门依法取缔,现场查扣成品啤酒100多箱以及110多箱过期红牛.雪碧和哈啤等"原料". 黑窝点 啤酒造假被查 29日16时20分许,记者赶到位于道外区团结镇恒西村的这处造假窝点. 这是一处平房,院落的一侧一个近百平方米的房间,便