美文网首页
技术知识点整理

技术知识点整理

作者: SeaseeYoul | 来源:发表于2018-03-08 07:11 被阅读17次

清除浮动

BFC清除浮动
浮动的父级末尾插入块级元素清除浮动

BFC(Block Formatting Contexts)意为“块级格式化上下文”。就是页面上的一个渲染区域,容器内的子元素不会对外面的元素布局产生影响,反之亦然。如何生成BFC:
float的值不为none;
overflow的值不为visible;
position的值不为relative和static;
display的值为table-cell,table-caption何inline-block中的任何一个。
规则:
内部的Box会在垂直方向,一个接一个地放置。
Box垂直方向的距离由margin决定。属于同一个BFC的两个相邻Box的margin会发生重叠
每个元素的margin box的左边, 与包含块border box的左边相接触(对于从左往右的格式化,否则相反)。即使存在浮动也是如此。
BFC的区域不会与float box重叠。
BFC就是页面上的一个隔离的独立容器,容器里面的子元素不会影响到外面的元素。反之也如此。
计算BFC的高度时,浮动元素也参与计算
IFC (Inline Formatting Contexts)意为“内联格式化上下文”,IFC中,盒子依次水平放置,从包含块的顶部开始。
GFC(GridLayout Formatting Contexts)意为“网格布局格式化上下文”当一个元素设置为display:grid的时候,此元素将获得一个独立的渲染区域,可以在网格容器上定义网格行和列,为每一个网格定义位置和空间。GFC和table的区别在于GridLayout会有更加丰富的属性来控制行列,控制对齐以及更为精细的渲染。
FFC(Flex Formatting Contexts)意为“自适应格式化上下文”,display值为flex或者inline-flex的元素将会生成自适应容器,当前只有谷歌和火狐支持该属性,不过在移动端几乎没有障碍(移动端是chrome和Safari的天下)。flex box由伸缩容器和伸缩子元素组成。通过设置元素display:flex/inline-flex可以得到伸缩容器,前者为块级元素,后者为行内元素。伸缩容器外元素不受影响。

display:none与visibility: hidden;的区别

占位,
背景图是否加载,为什么?
display:none的节点之后的dom节点不会被渲染 所以不会加载背景图
display:none 的性能次于 visibility: hidden;

高性能动画

1.开启GPU渲染
2.动画开始时机
3.降频与丢帧(批量渲染)
4.layout与painting

渲染原理/过程

1.dom树的构建
2.css规则树的构建
3.渲染树的构建(display:none的节点之下是不会构建的)
4.Layout,gen
4.GPU渲染
5.repaint / reflow

高性能css

1.css层叠深度
2.选择器的使用
3.可维护性
4.css属性

html语义化理解

  • 为了在没有CSS的情况下,页面也能呈现出很好地内容结构、代码结构:为了裸奔时好看;
  • 用户体验:例如title、alt用于解释名词或解释图片信息、label标签的活用;
  • 有利于SEO:和搜索引擎建立良好沟通,有助于爬虫抓取更多的有效信息:爬虫依赖于标签来确定上下文和各个关键字的权重;
  • 方便其他设备解析(如屏幕阅读器、盲人阅读器、移动设备)以意义的方式来渲染网页;
  • 便于团队开发和维护,语义化更具可读性,是下一步吧网页的重要动向,遵循W3C标准的团队都遵循这个标准,可以减少差异化。

js部分相关知识

element.getElementsByClassName
element.getElementById
element.getElementsByTagName
获取 / 设置属性 attr
element.getAttribute('test');
element.setAttribute('test', '1');
element.hasAttribute('test');
获取 / 设置 data
element.dataset['test'];
element.dataset['test'] = '1';
next / prev
element.previousElementSibling;
element.nextElementSibling;
其他操作
element.appendChild
element.insertBefore
element.removeChild
element.innerHTML
element.textContent
CLASS
element.classList.remove('test');
element.classList.add('test');
// jquery
$element.hasClass('test');
// native
element.classList.contains('test');
element.classList.toggle('test');
事件监听
element.addEventListener('click', fn, false);
element.removeEventListener('click', fn);
var event = document.createEvent('MouseEvents');
event.initEvent('click', true, true);

element.dispatchEvent(event);

css3部分相关知识

html部分相关知识

css相关知识

构建工具相关

Less / Scss

canvas VS svg

经典题目,打开一个网页的过程

1.本地浏览器DNS缓存查找(chrome://net-internals/#dnschrome://chrome-urls/
2.本地hosts匹配
3.DNS解析(在网络协议中属于传输层?)

ps:网络四层划分:数据链路层 传输层 网络层 应用层
七层划分:应用层,表示层,会话层;数据链路层,物理层

4.建立网络连接

三次握手相关

5.发起http请求(在网络协议中属于应用层)

并行下载,一边下载一边解析,js会造成阻塞,考虑defer async属性 及其区别

6.本地解析

dom树,css规则树,渲染树 布局 绘画 展示。这其中涉及到可以优化的点

PPS:中间可能涉及到的 缓存相关,出现在什么地方,以及浏览器缓存机制,服务器缓存机制。

相关文章

  • 技术知识点整理

    清除浮动 BFC清除浮动浮动的父级末尾插入块级元素清除浮动 BFC(Block Formatting Contex...

  • Android 路线

    Android学习之路 Android开发技术前线 Android重要知识点解析整理 Android6.0新特性详...

  • 页面布局

    本文主要讲述页面布局样式方面涉及的知识点,更全面的对CSS相应的技术进行归类、整理、说明,没有特别详细的技术要点说...

  • 微信小程序常用知识-基础篇

    整理一些微信小程序常用的技术知识点,入门之用。 一、事件绑定 bindtap 二、样式导入 @import 三、列...

  • 端午福利:2020年BAT面试题+Java架构师视频+PDF资料

    Java资料包里面包含: BAT面试文档+架构技术视频+求职简历模版+Java核心知识点整理+Java开发手册全集...

  • iOS开发小记-基础篇

    前两年学习过程中陆陆续续整理的知识点,今天开始迁移到掘金。由于当年在翻阅国产技术书籍时,发现知识点有不少错误,导致...

  • Spring+MySQL+数据结构+集合+注解+NIO+多线程思

    来自阿里的大神整理的Java技术思维导图,一个知识点一张图,整理的特别棒! 好东西当然要分享,需要高清版思维导图的...

  • java后端-Spring框架学习

    最近在学习java后端技术,目标全栈工程师。整理下Spring框架的知识点 Spring介绍 Spring是一个基...

  • iOS 开发进阶整理(持续更新...)

    第一次写技术性博客,有时间就将一些工具和知识点整理一下,方便一起交流,也方便自己学习整理。 个人Githup地址:...

  • 看书和思维导图很配

    看书和思维导图是非常配的,特别是技术书。思维导图帮助对书的结构,对技术的所有知识点进行概括和整理。 最近养成了一个...

网友评论

      本文标题:技术知识点整理

      本文链接:https://www.haomeiwen.com/subject/rcxjfftx.html