最近完成的项目总结

最近跟着师父做了一个完整的H5项目,连着加了三周的班,现在终于已经接近尾声。
填的坑与收益并存,所以就在此总结。

1. 填的坑

1。 最麻烦的就是UI及文案的问题了,毕竟是活动,设计那么费心,总要把页面写的和设计一模一样吧,写完页面之后还得进行好几轮的视觉走查,一点一点改,1px设计都能看出来,还有文案问题,过文案还得很多轮,直到最终确定,很琐碎的事情,但也需要很多耐心

2。 H5滑屏功能的实现:

第一种方法:利用translateY改变超长页面的坐标,超长页面也是由多个子页面组成,每次滑动一屏的距离就可以展示一屏的内容。刚开始用的是fullpage这个滑屏库,但是需求是首屏必须点击才能进入下一页,因为没有上下滑操作就进入了下一页,这样子hash和自然页面就对应不上,永远是第一个hash对应第二个页面,然后想到一种强制对应的解决方法,即点击过之后删除第一个hash,这样就可以让页面和hash强制对应。

第二种方法:但是最坑的一点是需求是必须要回到主视觉。。。fullpage又实现不了,,只能换方案。就用了react-touch这个库里面的swipeable 这个组件,通过上滑下滑事件触发回调,回调里面去通过判断进行滑屏操作,这样滑多少屏都是可控的,然后就很心酸的换了方案解决问题。。。

3。我终于遇到了移动端1PX的问题。。。

第一个问题:有一个弹窗中需要用一条线把标题和内容隔开,我用的border-bottom来实现的,然后就遇到了1PX问题,有的手机上1PX显示特粗,后来用0.5border 解决了这个问题,但是不是很兼容,有的手机上还是显示有问题,不过效果可以接受,就没有再继续做兼容了。

第二个问题: border-left:1PX #000000 dashed 在大屏手机上不显示。。。阿西吧真的是啥问题都能碰到,兼容性真的太恶心了。。。找了半天的原因,发现不仅是1PX的原因,还有虚线的问题,solid就不会出现不显示的问题。之后用background-image去解决,但是小屏手机比如是iPhone5上还是不显示,不过解决了大部分的兼容性问题,这个结果还是可以接受的

2. 解决的点

1)父子组件之间传值的问题,因为第一次接触react,这就也是需要我去解决的一个点

2)封装组件的问题,学会了应该怎么样去封装react组件,如何暴露接口等等

3)页面跳转,在JSX里面用link标签去跳转,在事件处理方法里面用this.props.hiatory.push(url) 去进行页面跳转,传参跳一个道理

4)串行请求接口,浪费网络资源,但是方便实现

3. 问题的发现与总结

1)布局时,能不用绝对定位,就一定不要用

2)图片应该统一起来放置,一些页面特有图片可以自行放置到文件目录下

3)移动端浏览器兼容。。。比如有的 app 用CSS的VH 单位和JS的document.documentElement.clientHeight 值不一样,但是有的一样,所以就要做一个兼容处理

4)上手之前一定要先搞懂需求,不然做完之后再对需求,就嗝屁了,不过改需求就是另外一回事了

就先总结这么多吧,毕竟刚来,做的都是一些基础的东西,技术性的东西等做完之后看看同事们是怎么做的并学习学习。

不是一篇技术性博客,只是总结一下自己这个项目以来遇到的问题及踩到的坑,并做以记录

你可能感兴趣的:(总结)