var arr = [1,2,3,4,5,6,7,8,9,10];
arr.sort(function(){
return Math.random() - 0.5;
})
console.log(arr);
复制代码
function deviceType(){
var ua = navigator.userAgent;
var agent = ["Android", "iPhone", "SymbianOS", "Windows Phone", "iPad", "iPod"];
for(var i=0; i<len,len = agent.length; i++){
if(ua.indexOf(agent[i])>0){
break;
}
}
}
deviceType();
window.addEventListener('resize', function(){
deviceType();
})
微信的 有些不太同样
function isWeixin(){
var ua = navigator.userAgent.toLowerCase();
if(ua.match(/MicroMessenger/i)=='micromessenger'){
return true;
}else{
return false;
}
}
复制代码
缘由: 由于各大浏览器都为了节省流量,作出了优化,在用户没有行为动做时(交互)不予许自动播放;
/音频,写法一
<audio src="music/bg.mp3" autoplay loop controls>你的浏览器还不支持哦</audio>
//音频,写法二
<audio controls="controls">
<source src="music/bg.ogg" type="audio/ogg"></source>
<source src="music/bg.mp3" type="audio/mpeg"></source>
优先播放音乐bg.ogg,不支持在播放bg.mp3
</audio>
//JS绑定自动播放(操做window时,播放音乐)
$(window).one('touchstart', function(){
music.play();
})
//微信下兼容处理
document.addEventListener("WeixinJSBridgeReady", function () {
music.play();
}, false);
//小结
//1.audio元素的autoplay属性在IOS及Android上没法使用,在PC端正常;
//2.audio元素没有设置controls时,在IOS及Android会占据空间大小,而在PC端Chrome是不会占据任何空间;
//3.注意不要遗漏微信的兼容处理须要引用微信JS;
复制代码
-webkit-user-select: none;
-ms-user-select: none;
-moz-user-select: none;
-khtml-user-select: none;
user-select: none;
复制代码
添加版权信息思路:css
一、答案区域监听copy事件,并阻止这个事件的默认行为。
二、获取选中的内容(window.getSelection())加上版权信息,而后设置到剪切板(clipboarddata.setData())。
复制代码
一、定位 盒子宽高已知, position: absolute; left: 50%; top: 50%; margin-left:-自身一半宽度; margin-top: -自身一半高度;
二、table-cell布局 父级 display: table-cell; vertical-align: middle; 子级 margin: 0 auto;
三、定位 + transform ; 适用于 子盒子 宽高不定时; (这里是本人经常使用方法)
position: relative / absolute;
/*top和left偏移各为50%*/
top: 50%;
left: 50%;
/*translate(-50%,-50%) 偏移自身的宽和高的-50%*/
transform: translate(-50%, -50%); 注意这里启动了3D硬件加速哦 会增长耗电量的 (至于何是3D加速 请看浏览器进程与线程篇)
四、flex 布局
父级:
/*flex 布局*/
display: flex;
/*实现垂直居中*/
align-items: center;
/*实现水平居中*/
justify-content: center;
再加一种水平方向上居中 :margin-left : 50% ; transform: translateX(-50%);
复制代码
***只适用于pc端
input::-webkit-input-placeholder {
/* WebKit browsers */
font-size:14px;
color: #333;
}
input::-moz-placeholder {
/* Mozilla Firefox 19+ */
font-size:14px;
color: #333;
}
input:-ms-input-placeholder {
/* Internet Explorer 10+ */
font-size:14px;
color: #333;
}
复制代码
window.onload必须等到页面内包括图片的全部元素加载完毕后才能执行。
$(document).ready()是DOM结构绘制完毕后就执行,没必要等到加载完毕。
window.onload不能同时编写多个,若是有多个window.onload方法,只会执行一个
$(document).ready()能够同时编写多个,而且均可以获得执行
复制代码
一、Array.isArray([1,2,3])
二、根据对象的class属性(类属性),跨原型链调用toString()方法(比较推荐)
Object.prototype.toString.call([1,2,3]);
三、从原型入手,Array.prototype.isPrototypeOf(obj);
复制代码
[跨域资源共享 CORS 详解](http://www.ruanyifeng.com/blog/2016/04/cors.html)
感谢[面试的信心来源于过硬的基础](https://segmentfault.com/a/1190000013331105)这篇文章的分享
另外添加两个github上整理的面试题
[https://github.com/qiu-deqing/FE-interview](https://github.com/qiu-deqing/FE-interview)、[https://github.com/fouber/blog](https://github.com/fouber/blog)
复制代码
1)盒子模型有两种,W3C和IE盒子模型
(1)w3c的盒模型width=content,不包括margin,padding,border
(2)IE盒模型width=content+padding+border
(3)box-sizng border-box在已设定的宽度和高度以内去设定padding和border
content-box在已设定的高度和宽度以外设置padding和border
复制代码
(1)行内元素:
a - 锚点,em - 强调,strong - 粗体强调,span - 定义文本内区块,i - 斜体,img - 图片,b - 粗体,label-表格标签,select-项目选择,textarea-多行文本输入框,
sub - 下标,sup - 上标,q - 短引用,
(2)块元素:
div - 经常使用块级,dl-定义列表,dt,dd,ul-非排序列表,li,ol-排序表单,p-段落,h1,h2,h3,h4,h5-标题,table-表格,
fieldset - form控制组,form - 表单,
(3)空元素:
br-换行,hr-水平分割线
复制代码
(1)href:
href是Hypertext Reference的缩写,表示超文本引用。用来创建当前元素和文档之间的连接。如link a 并行下载该文档,而且不会中止对当前文档的处理
(2)src:
src是source的缩写,src指向的内容会嵌入到文档当前标签所在位置
如img、script、iframe当浏览器解析到该元素时,会暂停浏览器的渲染,直到该资源加载完毕。
复制代码
CSS hack是经过在CSS样式中加入一些特殊的符号,让不一样的浏览器识别不一样的符号,以达到应用不一样的CSS样式的目的
复制代码
优雅降级:一开始就构建功能完整的网站,而后根据低版本浏览器进行兼容。
渐进加强:针对低版本浏览器,保证最基本的功能,而后再根据高版本的浏览器进行交互功能的升级。
复制代码
function New(func){
var res = {};
if(func.prototype !== null){
res.__proto__=func.prototype;
}
var set = func.apply(res,Array.prototype.slice(arguments,1));
if((typeof set === "object" || typeof set === "function")&&rest !== null){
return set;
}
return res;
}
var obj = New(A,1,2) === var obj = new A(1,2)
function _new(fn, ...arg) {
const obj = Object.create(fn.prototype);
const ret = fn.apply(obj, arg);
return ret instanceof Object ? ret : obj;
}
复制代码
var obj ={q:1,w:[{e:1},2],r:{t:'123'}};
function deepClone(obj){
if(!obj || (typeof obj !== 'object')){
return;
}
var newObj = Object.prototype.toString.call(obj) == '[object Array]'?[]:{};
for(let key in obj){
if(typeof obj[key] == 'object'){
newObj[key] = deepClone(obj[key])
}else{
newObj[key] = obj[key];
}
}
return newObj;
}
console.log(deepClone(obj)==obj)
console.log(deepClone(obj))
复制代码
一、意外的全局变量html
// bar变量未声明 解决办法就是使用js严格模式 'use strict'(严格模式下this 为undefind)
function foo(){
bar='123';
}
复制代码
二、定时器和回调函数node
// 定时器
var someResource = getData();
setInterval(function() {
var node = document.getElementById('Node');
if(node) {
// 处理 node 和 someResource
node.innerHTML = JSON.stringify(someResource));
}
}, 1000);
// 回调函数
var element = document.getElementById('button');
function onClick(event) {
element.innerHTML = 'text';
}
element.addEventListener('click', onClick);
复制代码
现代的浏览器(包括 IE 和 Microsoft Edge)使用了更先进的垃圾回收算法(标记清除),已经能够正确检测和处理循环引用了。即回收节点内存时,没必要非要调用 removeEventListener 了。现代的浏览器(包括 IE 和 Microsoft Edge)使用了更先进的垃圾回收算法(标记清除),已经能够正确检测和处理循环引用了。即回收节点内存时,没必要非要调用 removeEventListener 了。ios
三、脱离dom的引用git
四、闭包 定义:闭包是指有权访问另一个函数做用域中的变量的函数github
闭包三个特性:web
(1)能够访问当前函数之外的变量 (2)即便外部函数已经返回,闭包仍能访问外部函数定义的变量 (3)闭包能够更新外部变量的值面试