//html <div class='box'><div class='left'></div> <div class='right'></div></div>
//css .box{ width: 400px; height: 100px; display: flex; flex-direction: row; align-items: center; border: 1px solid #c3c3c3; } .left { flex-basis:100px; -webkit-flex-basis: 100px; /* Safari 6.1+ */ background-color: red; height: 100%; } .right { background-color: blue; flex-grow: 1; }
在线demojavascript
<div id="left">Left sidebar</div> <div id="content">Main Content</div>
<style type="text/css"> *{ margin: 0; padding: 0; } #left { float: left; width: 220px; background-color: green; } #content { background-color: orange; margin-left: 220px;/*==等于左边栏宽度==*/ } </style>
1.减小dom操做
2.部署前,图片压缩,代码压缩
3.优化js代码结构,减小冗余代码
4.减小http请求,合理设置 HTTP缓存
5.使用内容分发cdn加速
6.静态资源缓存
7.图片延迟加载html
输入地址
1.浏览器查找域名的 IP 地址
2.这一步包括 DNS 具体的查找过程,包括:浏览器缓存->系统缓存->路由器缓存...
3.浏览器向 web 服务器发送一个 HTTP 请求
4.服务器的永久重定向响应(从 http://example.com 到 http://www.example.com)
5.浏览器跟踪重定向地址
6.服务器处理请求
7.服务器返回一个 HTTP 响应
8.浏览器显示 HTML
9.浏览器发送请求获取嵌入在 HTML 中的资源(如图片、音频、视频、CSS、JS等等)
10.浏览器发送异步请求前端
1.跨域问题
2.设置了HttpOnlyvue
1.直接改变className,若是动态改变样式,则使用cssTextjava
// 很差的写法 var left = 1; var top = 1; el.style.left = left + "px"; el.style.top = top + "px";// 比较好的写法 el.className += " className1"; // 比较好的写法 el.style.cssText += "; left: " + left + "px; top: " + top + "px;";
2.让要操做的元素进行”离线处理”,处理完后一块儿更新
a) 使用DocumentFragment进行缓存操做,引起一次回流和重绘;
b) 使用display:none技术,只引起两次回流和重绘;
c) 使用cloneNode(true or false) 和 replaceChild 技术,引起一次回流和重绘nginx
1.beforcreate
2.created
3.beformount
4.mounted
5.beforeUpdate
6.updated
7.actived
8.deatived
9.beforeDestroy
10.destroyedweb
一、经过jsonp跨域
二、经过修改document.domain来跨子域
三、使用window.name来进行跨域
四、使用HTML5中新引进的window.postMessage方法来跨域传送数据(ie 67 不支持)
五、CORS 须要服务器设置header :Access-Control-Allow-Origin。
六、nginx反向代理 这个方法通常不多有人说起,可是他能够不用目标服务器配合,不过须要你搭建一个中转nginx服务器,用于转发请求json
开发规范
模块化开发
组件化开发
组件仓库
性能优化
项目部署
开发流程
开发工具设计模式
1.使用jq的$.extend(true, target, obj) 2.newobj = Object.create(sourceObj),// 可是这个是有个问题就是 newobj的更改不会影响到 sourceobj可是 sourceobj的更改会影响到newObj 3.newobj = JSON.parse(JSON.stringify(sourceObj))
整体来讲设计模式分为三大类:
建立型模式,共五种:工厂方法模式、抽象工厂模式、单例模式、建造者模式、原型模式。
结构型模式,共七种:适配器模式、装饰器模式、代理模式、外观模式、桥接模式、组合模式、享元模式。
行为型模式,共十一种:策略模式、模板方法模式、观察者模式、迭代子模式、责任链模式、命令模式、备忘录模式、状态模式、访问者模式、中介者模
详细说明
请移步alloyteam的文章
<input type="file" name="file" onchange="showPreview(this)" /> <img id="portrait" src="" width="70" height="75">
function showPreview(source) { var file = source.files[0]; if(window.FileReader) { var fr = new FileReader(); fr.onloadend = function(e) { document.getElementById("portrait").src = e.target.result; }; fr.readAsDataURL(file); } }
var result = [] function unfold(arr){ for(var i=0;i< arr.length;i++){ if(typeof arr[i]=="object" && arr[i].length>1) { unfold(arr[i]); } else { result.push(arr[i]); } } } var arr = [1,3,4,5,[6,[0,1,5],9],[2,5,[1,5]],[5]]; unfold(arr)
var c=[1,3,4,5,[6,[0,1,5],9],[2,5,[1,5]],[5]]; var b = c.toString().split(',')
var arr=[1,3,4,5,[6,[0,1,5],9],[2,5,[1,5]],[5]]; const flatten = arr => arr.reduce((a, b) => a.concat(Array.isArray(b) ? flatten(b) : b), []); var result = flatten(arr)
iframe会阻塞主页面的Onload事件;搜索引擎的检索程序没法解读这种页面,不利于SEO;iframe和主页面共享链接池,而浏览器对相同域的链接有限制,因此会影响页面的并行加载。使用iframe以前须要考虑这两个缺点。若是须要使用iframe,最好是经过javascript动态给iframe添加src属性值,这样能够绕开以上两个问题。