一个H5项目的实践与总结
ripr9642
8年前
<h3>一、背景来源:</h3> <p>9月份找工作的时候,接到腾讯笔试题,一个H5项目,于是自己花了三天时间去做,交给了面试官后,面试官要求我再优化一下,可惜当时自己不懂事,以为没啥希望,就没有去优化和争取;选择另外一家公司入职了,现在想想后悔不已,如果再给我一次机会,我一定好好珍惜<(▰˘◡˘▰)>。最近两天有时间,重构、优化了下这个项目。发现自己之前写得有点糟糕,当然现在优化得可能还是不够好(/ □ \),看下现在的效果:</p> <p><img src="https://simg.open-open.com/show/8286e94ad2d45d1c535b29ee5882ed24.gif"></p> <h3>二、实践:</h3> <p>1.rem响应式布局:</p> <p>我之前用媒体查询,html的font-size设置为10px:</p> <pre> <code class="language-html"> /*媒询*/ /* html{ font-size: 10px; height: 100%; font-family: "Microsoft Yahei"; -webkit-text-size-adjust: none; } @media screen and (max-width:349px) { html { font-size: 10px; -webkit-text-size-adjust: none; } } @media screen and (min-width:350px) and (max-width:374px) { html { font-size: 11px; -webkit-text-size-adjust: none; } } @media screen and (min-width:375px) and (max-width:410px) { html { font-size: 12px; -webkit-text-size-adjust: none; } } @media screen and (min-width:411px){ html { font-size: 13px; -webkit-text-size-adjust: none; } } */ View Code</code></pre> <p>这个导致的结果是,在chrome浏览器下,一直都是12px,我自己调试的时候发现无论怎么设置图片的rem,图片的宽度都没有变化,所以需要注意:</p> <p>问:设置html font-size:10px;Chrome下1rem=12px,在火狐下1rem == 10px;为什么?如何让Chrome 1rem=10px?</p> <p>答:因为谷歌浏览器里,字体最小大小为12px,无法再小了 你可以再css里面加上这句 -webkit-text-size-adjust:none; 这样就可以了,</p> <p>追答: 不管用,这条样式在最新版的chrome里已经弃用了。</p> <p>所以后面我用了这种办法来实现rem响应式布局(拿到的设计稿是640px)</p> <pre> <code class="language-html">(function (doc, win) { var docEl = doc.documentElement, resizeEvt = 'orientationchange' in window ? 'orientationchange' : 'resize', recalc = function () { var clientWidth = docEl.clientWidth; if (!clientWidth) return; if(clientWidth>=640){ docEl.style.fontSize = '100px'; }else{ docEl.style.fontSize = 100 * (clientWidth / 640) + 'px'; } }; if (!doc.addEventListener) return; win.addEventListener(resizeEvt, recalc, false); doc.addEventListener('DOMContentLoaded', recalc, false); })(document, window); </code></pre> <p>这样在不同移动设备下的font-size为:</p> <p>iphone5:</p> <p><img src="https://simg.open-open.com/show/9e5d6c36c79ffa8912993d110f020d6a.png"></p> <p>iphone6:</p> <p><img src="https://simg.open-open.com/show/7c9456559051594229999f2479bdecf4.png"></p> <p>(注意:这种情况下,以640px的设计稿为准,对应设计稿的切图,直接以原图大小保存就好,切出来的图片,宽度设置为设计稿中的尺寸除以100。布局时,设计图标注的尺寸除以100得到css中的尺寸)</p> <p>2.对于第三页布局的重构:</p> <p><img src="https://simg.open-open.com/show/77ab9de5a568499987d2456783c85e3a.png"></p> <p>①.画线动画:</p> <pre> <code class="language-html"><div class="page3_line2"> <div class="page3_line2_div"> </div> </div> </code></pre> <pre> <code class="language-html">.page3_line2 { position: absolute; z-index: 55; transform: rotate(170deg); overflow: hidden; top: .35rem; right: .5rem; } .page3_line2_div { margin-left: -100%; width: 3.8rem; height: 1px; background: #cdb04a; transition: all 0.4s 0.6s; } .page3_line2_div_move { margin-left: 0px; } </code></pre> <p>这个.page3_line2_div_move是在js中添加的</p> <pre> <code class="language-html"> //第三页,需要画线 if (this._curIndex == 2) { setTimeout(function() { $(".page3_line1_div").addClass('page3_line1_div_move'); $(".page3_midstar").addClass('page3_midstar_move'); $(".page3_line_div").addClass('page3_line1_div_move'); $(".page3_smallstar").addClass('page3_midstar_move'); $('.page3_txt1').addClass('txtleft_animate'); $('.page3_home').addClass('page3_home_move'); $('.page3_point').addClass('page3_point_move'); $('.page3_line2_div').addClass('page3_line2_div_move'); $('.page3_point2').addClass('page3_point2_move'); $('.page3_prostar').addClass('page3_prostar_move'); $('.page3_line3_div').addClass('page3_line3_div_move'); $('.page3_txt2').addClass('txtleft_animate'); $('.page3_point3').addClass('page3_point3_move'); $('.page3_fly').addClass('page3_fly_move'); $('.page3_txt3').addClass('txtleft_animate'); $('.page3_line4_div').addClass('page3_line4_div_move'); $('.page3_point4').addClass('page3_point4_move'); $('.page3_q').addClass('page3_stamp_move'); $('.page3_stamp').addClass('page3_stamp_move'); }, 500); View Code</code></pre> <p>动画的先后出现顺序都是通过</p> <pre> <code class="language-html">transition: all 0.4s 0.6s;</code></pre> <p>最后一个参数(0.6s)来控制的。</p> <p>②.移动设备适配性问题:</p> <p>这里要注意下布局的技巧,或者说是布局的规范,为了实现画线过程中,点与线衔接,需要在这些元素外面额外加一个div,设置为position:relative;然后里面的点与线的div都设置为position:absolute;以父级div位置作为参考,然后再对里面的点与线布局,这样就能保证他们的位置始终是契合的。</p> <p>我的页面布局为:</p> <pre> <code class="language-html"> <div class="page3_point_line_wrap"> <div class="page3_point"></div> <div class="page3_line2"> <div class="page3_line2_div"> </div> </div> <div class="page3_point2"></div> <img src="img/page3_star.png" class="page3_prostar"> <div class="page3_txt2">已累计获得5星<span>2次</span>啦</div> <div class="page3_line3"> <div class="page3_line3_div"> </div> </div> <div class="page3_point3"></div> <img src="img/page3_fly.png" class="page3_fly"> <div class="page3_txt3">超越了<span>92.6%</span>的鹅厂精英</div> <div class="page3_line4"> <div class="page3_line4_div"> </div> </div> <div class="page3_point4"></div> <img src="img/page3_q.png" class="page3_q"> <img src="img/page3_stamp.png" class="page3_stamp"> </div> View Code</code></pre> <p>把最外层div设置为position: relative;</p> <pre> <code class="language-html">.page3_point_line_wrap { position: relative; } </code></pre> <p>里面的元素根据设计图位置布局。</p> <p>测试后,发现这种做法适配了移动端各种设备。之前我的布局没有考虑到这些,直接布局,导致出现不同移动端设备下,出现布局混乱的情况。</p> <p>3.hammer.js的应用:</p> <p>滑动效果的实现是用了hammer.js;作业交过去后,面试官提出,滑动效果不太顺畅,看了下代码,发现可能的原因是这里:</p> <pre> <code class="language-html"> var onEnd = function(e) { var deltaY = e.deltaY; //滑动Y轴偏移量少于一定最少距离 ,保留在当前页 if (Math.abs(deltaY) < self.minDis) { // debugger; self.toNext(e); } else { if (deltaY < 0) { self.toNext(e); } else { self.toPrev(); } } //停止动作 var _distanY = self.winHeight * (self._curIndex); self.toPosition(_distanY); } </code></pre> <p>滑动Y轴偏移量少于一定最少距离,保留在当前页,之前是没有self.toNext(e)这个方法。后面我添加这个方法试了下,好像是会顺畅些。滑动页面还要注意有动画效果:</p> <pre> <code class="language-html">.page_animate_0d5s { height: 100%; position: relative; transform: translate3d(0px, 0px, 0px); transition: all 700ms ease; } </code></pre> <h3>三、总结:</h3> <p>可取之处:</p> <p>1.代码的命名;(以页面为准,每页的命名加个page(1-7),这样方便自己维护代码;图片的命名也比较规范,属于哪一页的图,会在前面加个page(1-7) )。</p> <p>2.注释及代码格式;(自己重构的过程中,不会觉得混乱,可能是因为是自己写过的代码 ( ̄工 ̄lll) )。</p> <p>不足之处:</p> <p>1.缺乏思考;之前有参与公司的移动端项目,不过也是别人搭好的框架(用的是媒体查询),然后写了几个简单的页面,没有从整体去思考,移动端该怎么布局,比如内容页面需要设置一个最大宽度max-width。</p> <p>2.对自己写的代码要求过低,代码不够规范;工作中,也有负责过一个简单H5项目,没有涉及到什么动画及点线组合,现在想想当时自己写的应该也是有适配性问题,惭愧 ( # ▽ # ) 。</p> <p>3.多去学习,实践;响应式布局,我还只会用这个方法的rem布局,不会淘宝的做法( <strong>lib-flexible</strong> ),hammer.js这个好像还有更好的替代者( <strong>AlloyFinger</strong> ),我暂时都没用过 (┬_┬) 。</p> <p>4.再想想,也不是想要自己学太多;希望自己能理解自己用到的,然后把代码写好 (◕ˇ∀ˇ◕) 。</p> <p>最后:</p> <p>我的这个H5项目可以在这里看: <a href="/misc/goto?guid=4959725722811795422" rel="nofollow,noindex">线上效果</a> 。</p> <p>代码在: <a href="/misc/goto?guid=4959725722903829328" rel="nofollow,noindex">源代码</a> (这个弄得有点尴尬⊙﹏⊙‖∣)</p> <p> </p> <p>来自:http://www.cnblogs.com/wj204/p/6078776.html</p> <p> </p>