Effective前端1---chapter 1 HTML/CSS优化

最近在读高效前端:web高效编程与优化实践,借此本书的感受总结下前端代码与性能优化,纯属自己见解,如有错误,欢迎指出。

1.能用HTML/CSS解决的问题就不要用js

场景1:鼠标悬浮时显示

鼠标悬浮在菜单上时,显示子菜单。

实现思路:刚开始隐藏掉子菜单,信息框作为hover目标的子元素或者相邻元素,才方便使用CSS控制。

.menu{

    display:none; 

}

当导航hover时结合相邻选择器,把子菜单显示出来;

.find:hover + .menu{    display:list-item;}

//保证menu本身在hover的时候也要显示,

.menu:hover{

display:list-item;

}

.menu菜单的位置可以使用绝对定位显示在你想要显示的位置。

场景2:自定义radio/checkbox的样式

在我们使用原生的单选或者复选框时,不能满足我们的需求时,需要自己定制其样式。

两种方法:(1)使用label元素的绑定选中,修改其样式

<label for="checkbox_1">

        <input type="checkbox" id="checkbox_1">

        <span class="checkbox"></span>

        HELLO WORLD

</label>

/**            复选样式(使用label选中)        */        label{            cursor: pointer;            display: block;        }

//隐藏input        label input[type=checkbox]{            display: none;        }

//使用span的样式代替原生input样式        label input[type="checkbox"] + .checkbox{            box-sizing: border-box;            display: inline-block;            width: 16px;            height: 16px;            border: #ccc 1px solid;            border-radius: 3px;            position: relative;            top: 2px;        }        input[type=checkbox]:checked + .checkbox{            border: #307bb5 1px solid;            background-color: #307bb5;        }        input[type=checkbox]:checked + .checkbox::after{            content: '✔';            position: absolute;            top: -3px;            left: 1px;            color: #fff;            transition: all 0.3s linear;            font-size: 14px;        }

上述做法必须要保证label绑定对应input的值,否则不会生效;

效果如下图:

(2)直接使用input的伪类实现

<input type="checkbox" id="">

//隐藏原生复选框样式

input[type=checkbox]{    appearance: none;    -webkit-appearance: none;    outline: none;    margin: 0;    /* 将 */    position: relative;      top: 2px;

}

//显示的复选框样式input[type=checkbox]:after {            box-sizing: border-box;            display: block;            content: "";            width: 16px;            height: 16px;            background: #fff;            border-radius: 3px;            border: 1px solid #aaa;}

//选中后复选框样式input[type=checkbox]:checked:after{            box-sizing: border-box;            border: #307bb5 1px solid;            background-color: #307bb5;            text-align: center;            content: '✔';            color: #fff;            transition: all 0.3s linear;            font-size: 12px;            position: relative;            top: -2px;

}

效果如下:

此种方法的好处就是不需要多余的标签,可以实现改变原生样式。但是也存在一个小问题,感兴趣的小伙伴可以去试一下。(以上content里用到的对号是搜狗输入法的特殊符号)

场景3:使用表单提交

表单提交存在两种方式,一个AJAX,另一种是表单提交。如下:如果点击搜索按钮后要跳转到列表页,我们就可以使用表单提交

<form action="/search" id="search-form">

        <input type="search" name="keyword">

        <input type="email">

</form>

把所有的字段的名字写在input的name里面,然后form的action作为搜索页的链接,这样就可以实习那不用一行js实现搜索跳转。

如果需要表单验证的话,那就监听submit事件做验证,验证通过后调用原生表单元素的submit函数就可以实现表单提交,不需要手动获取form的值。

场景4:巧用CSS3伪类元素

CSS3的伪类提供了状态切换特性,除了以上实现的单选复选样式的:checked之外,还有focus,invalid等等。如下:

input获取焦点后,width发生改变。

实现:

.search{    width:100px;  }

//input获取焦点后样式input[type=search]:foucs + .search{    width:200px;}

还有一些输入框输入不合法时,例如提交按钮置灰,下一步按钮置灰等等操作,可以使用input的type和pattern等属性约束合法性,然后触发:invalid,实现以上操作。

场景5:用CSS3的attr属性实现简单的tooltip效果

当要实现一个hover的时候显示提示信息,如果使用title属性觉得效果不好看,又不想使用JS写,这时可以使用CSS3的attr属性实现。

<p>

      hello,

      <span data-title='Effective Frontend Development'>EFED</span>

</p>

span[data-title]{        position: relative; }

//定义显示框的样式span[data-title]:hover::before{      content: attr(data-title);      position: absolute;      top: 150%;      left: 50%;      transform: translateX(-50%);      white-space: nowrap;      border: 1px solid #ccc;      padding: 5px 10px;      border-radius: 5px;}

效果如下图:另外,你也可以使用after画一个三角形,指向要显示的元素位置。


 JS是万能的,几乎可以做任何事情,但有时候会显得笨拙,我们要学会在JS/HTML/CSS之间选择适合的开发形式,尽可能的简化开发,提升自己。

另外,这样的场景还有很多,像自动监听回车事件用于提交,导航悬浮,多列等高等等,这里就不再赘述。

 2.HTML语义化(优化HTML标签)

HTML5提供了许多语义化标签,每个标签都有相应的作用,浏览器会根据不同语义作出相应的反应。

就像input标签,在移动web开发的是,不同type值,会调用不同的键盘,如下:

不同的标签代表有着不同的作用:

div: 作为一个普通的容器使用;

section:作为一个普通的章节使用;

article:适用于独立性比较强的内容,如网页的主题就可以使用article标签;

nav:适用于导航内容;

aside:用作和页面主题相关的容器,像侧边栏,评论等辅助的元素

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 206,214评论 6 481
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 88,307评论 2 382
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 152,543评论 0 341
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 55,221评论 1 279
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 64,224评论 5 371
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,007评论 1 284
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,313评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,956评论 0 259
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 43,441评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,925评论 2 323
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,018评论 1 333
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,685评论 4 322
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,234评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,240评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,464评论 1 261
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,467评论 2 352
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,762评论 2 345

推荐阅读更多精彩内容

  • 第一部分 HTML&CSS整理答案 1. 什么是HTML5? 答:HTML5是最新的HTML标准。 注意:讲述HT...
    kismetajun阅读 27,422评论 1 45
  • 问答题47 /72 常见浏览器兼容性问题与解决方案? 参考答案 (1)浏览器兼容问题一:不同浏览器的标签默认的外补...
    _Yfling阅读 13,728评论 1 92
  • 2018年7月18日星期三 今天是第一天写JAVA编程的学习笔记。上一次写代码已经是四年前了,这几年几乎和代码绝了...
    关二少阅读 183评论 0 0
  • 01 “你好,请问是戈小姐吗?这里是EF英语打来的电话。” 我正盯着电脑屏幕,感觉有些头晕脑胀。这时看手机上有来电...
    烟雨红晨阅读 1,178评论 6 4
  • 热,太阳太毒了,远处的空气中都似乎有了火焰的味道。 静怡左手打着伞,右手护着孩子,走在无遮无拦的路上,任凭汗水在脸...
    于一潇阅读 1,058评论 20 25