年初随笔

2017年也已经开始了快一个月的时间了,然而我却好像没有跨进新一年的感觉

过去的一年里,前端开发这个行业的变化给我的感觉实在是快得有点眼花缭乱应接不暇

各种工程化工具,各种新框架占据了这个行业里人们日常讨论的话题

然而反思回自己的团队,仍然是停留在比较基础的开发流程。不得不让我恍然醒悟,自己真是半年的经验凑合用了两年。

所以选择在这样一个时间,记录下自己的这半年经验,做为一个分隔线,让自己突破现在的状态。

移动开发篇:

最先接触的移动端自适应的做法,大概是手淘家的flexible.js

具体做法就是通过控制html根元素的font-size值搭配rem单位来实现的适应。有个值得注意的地方是flexible还通过动态生成meta标签来改变viewport缩放,实现对iphone系列的高度自适应(语文不好真不知道怎么形容),达到一个在Retina屏幕下页面显示质量也不会受太大影响

后来刷论坛的时候,接触到了一些其他大神的做法,比如我现在也在使用的通过calc属性来改变html的font-size值来实现的适应,搭配媒体查询来实现一些低版本浏览器的兼容,毕竟布局本来就是html和css的职责,能不用js来实现就尽量不用

flex布局:

flex在移动端上确实非常好用,基本可以代替float和定位,垂直居中也比以往的display-table来的方便。

唯一要注意的就是flex有一个早期版本的兼容写法

现在的语法:

/*父容器*/
    .box{
        display:-webkit-flex;

        display:flex;

        /*行内元素也可也用flex*/
        display: inline-flex;
    }
    /*父容器样式*/
    .box{
        /*主轴方向*/
        flex-direction:row; /*row:从左到右   column:从上到下*/

        /*主轴对齐*/
        justify-content:center;/*flex-start:左对齐  flex-end:右对齐   space-between:两端对齐*/

        /*交叉轴对齐*/
        align-items:center;/*flex-start:顶部对齐  flex-end:底部对齐*/
    }
    /*子元素*/
    .item{
        /*排序*/
        order:0; /*数值越小排越前*/

        /*元素放大比例,0表示不放大*/
        flex-grow:0;

        /*元素缩小比例,0表示不缩小*/
        flex-shrink:1; 

        /*固定大小*/
        flex-basis: 1;

           /*综合上面三种的简写,默认值0 1 auto*/
        flex:xx;
    }

旧版本兼容语法:(发现有兼容问题可以尝试加上此兼容写法)

/*父容器*/
    .box{
        display:-webkit-box;
        display:box;
    }
    /*父容器样式*/
    .box{
        /*排列方式*/
        box-orient:horizontal; /*horizontal:水平方向   vertical:垂直*/

        /*方向*/
        box-direction:normal; /*normal:默认方向   reverse:反方向*/

        /*主轴对齐*/
        box-pack:center;/*start:左对齐  end:右对齐   justify:两端对齐*/

        /*交叉轴对齐*/
        box-align:center;/*start:顶部对齐  end:底部对齐*/
    }
    /*子元素*/
    .item{
        /*排序*/
        box-ordinal-group:0; /*数值越小排越前*/

        box-flex:xx;
    }

移动端踩坑系列:

click延迟:

说起移动端上的坑,估计第一个都会想到click的延迟,由于我们的采用的框架是zepto,所以可以用tap事件来提高点击体验。

早期的zepto上的tap事件还有一个"点透"的问题,可以通过采用类似loading弹出层的方式来阻止后发的click事件作用到我们的目标页面。不过最新版本的zepto已经解决这个问题,可以放心引用。

目前所知解决延迟的方式还有fastclick.js;如果什么插件库都不想引用的话,可以尝试使用loading弹层的方式来减少用户的延迟感

元素点击响应的默认边框和触摸遮罩:

-webkit-tap-highlight-color:transparent; 可以将触摸的遮罩颜色透明化,当然也可而已设置为其他颜色

按钮点击的active效果:

移动端上的hover和active事件都是无效的,可以给该元素绑定一个空的touchstart的空事件,可以激活active效果

也可以通过touchstart和touchend来增减类名,不过在性能比较差的机子上会出现长按释放后样式一直存在的问题

获取元素最终应用到的样式:

前面说过通过改变根元素的font-size值搭配rem单位来做适配的方法,这个时候就需要准确的获取根元素的font-size值

而element.sytle.fontSize是取不到样式表上的属性值的,要去到样式表上的应用的样式,必须用getComputedStyle。

border-radius的背景色溢出:

一些旧版本的系统或浏览器会出现当border-radius和背景色同时存在的时候,圆角以外的部分也会有背景色溢出

此时可以加上 background-clip:padding-box 来修复

background-clip规定了背景的绘制区域,padding-box表示将背景裁剪到内边距里

结尾:

碎碎念的东西到这里就先结束吧,祝全天下新年快乐

时间: 2024-08-20 21:22:01

年初随笔的相关文章

2018年的随笔总结跟19年的预计(挖波年初的矿)

其实有点汗颜,我这个博客是之前学Python的时候老师让申请的,之后也没好好学,所有博客也没有用,今天休息在家没事想起来应该写点东西,但是不知道写在哪里,才想起来有这个东西,没有好友什么的,也正好适合随便写:刚登上来看了一下就只有17年的时候写的一篇关于Python的文章,当时觉得写的挺烂的,现在看其实也还好起码是写了的,再看看18年一点东西都没有才想真的要有个记录的习惯会比较好,不然呢自己都不知道你曾经干了什么,就想我现在18年也没发过什么朋友圈也没有记录什么就感觉不知不觉间过去了至于干了什么

C#博客随笔之六:数据绑定

这一篇随笔记录的是在完成程序中遇到的一些情况 首先要讲的是MVVM 所谓MVVM就是Model,View,ViewModel 下面是MVVM的优点(引用自百度百科): MVVM模式和MVC模式一样,主要目的是分离视图(View)和模型(Model),有几大优点1. 低耦合.视图(View)可以独立于Model变化和修改,一个ViewModel可以绑定到不同的"View"上,当View变化的时候Model可以不变,当Model变化的时候View也可以不变.2. 可重用性.你可以把一些视图

Abby's 学习php5随笔

2017.6.27 Abby's cakephp2 学习之旅 下载了XAMPP集成开发环境,然后配置其数据库,参考学习教程, 1.建立表单. 配置完信息如下,Cache Apache默认在windows下是system用户,所以权限最高,但xampp集成环境中的apache确是administor 如何更改apache用户为system 静默开发.(一种开发方法,番茄ToDo中的学霸模式有些相似) 如何设置.ctp的显示 http://cakephp2.local/posts/index怎么就可

java基础随笔 字符数据类型char的单引号

public class Love{ public static void main(String[] args){ System.out.println('*'+'\t'+'*'); System.out.println("*"+"\t"+"*") } } 运行结果   第一行为  93 第二行为  *        * 原因 第一行中'\t' 单引号  识别为字符数据类型char,char类型是可以运算的,在第一行中+做了运算符. 第二行&q

web前端学习随笔

好好算下来,学习web前端已有半个月了,这半个月来主要学习的是HTML和CSS部分,期间有困惑,也有解决困惑时的快感,所以想把这段时间感受到的一些东西记下来,因为内容比较杂,所以干脆叫随笔吧.这里面不会说前端的相关基础知识,只是说一些自己对前端的一些认识. html是用来控制页面结构的我曾经对这句话有过疑问,觉得html应该是控制页面内容的,为什么要说是控制页面结构的呢?在查看京东首页的代码时,我恍然大悟,html确实是定义页面内容的,但同时它也要控制页面的结构.举例来说,京东商品分类的div包

JavaWeb学习随笔

Servlet学习随笔 1.HttpServlet init(ServletConfig)------Servlet生命周期中的初始方法,默认情况是服务器创建后第一次访问这个Servlet时调用,可以修改配置信息,使其在服务器一创建时就被调用; 修改配置信息的方法-----在web.xml的<servlet>下添加<load-on-startup>x<load-on-startup>,x是正整数,越小表示优先级越高 url路径的配置,完全匹配>目录匹配>(.

想知道博客园随笔总阅读量吗?

我真的是闲的无聊了...,前提是你写的随笔总数少于等于40条. 0.在选项里设置一页显示40条随笔 1,打开自己的随笔列表:https://i.cnblogs.com/posts 2,在当前页面f12打开浏览器控制台 3,粘贴进去以下代码 var trs=document.querySelectorAll('#post_list tr td:nth-child(4)')//取得阅读量 atrs=Array.from?Array.from(trs):Array.prototype.slice.ca

随笔1104

随笔1104 一.变量定义 var a = 10; 如果定义小数或整数的变量,等号后面值直接写 如果定义字符串的变量,等号后面的值要加双引号或单引号 类型转换 parseInt(); 强制转换为整数 parseFloat();强制转换为小数 二.运算符表达式 1.数学运算符 + - * / % 百分号是取余 例:alert(a+b); alert(a%b); a除以b的余数 2.逻辑运算符 && 并 指两者都满足 || 或 指两者其中任何一个满足 ! 非 指强制变反 真变假 假变真 3.比

alpha发布(技术随笔)

昨天是班级里面每个小组要进行alpha演示,大家都很努力的去做自己的项目.我们nice!组没有演示自己的项目,只一点很惭愧,身为组员没有协助组长按时完成项目,这一点自己也感觉很抱歉,虽然每天感觉自己都有去做,但是效果非常不理想.看到天天向上组的连连看界面做的很好,有背景切换,主题,游戏的级别等做的很细心.先锋组的俄罗斯方块也不错,看到同学玩的那么开心就知道了,还有飞天小女警的礼物挑选真的很用心,这个idea就很新颖,而且完成的也很好,老师也说如果转换成手机app那就更方便使用了,市场很好. 这次