学习web前端你的小伙伴都是知道的js是一个门槛,如果学不会js对于日后的开发也是有一定的影响的,但是怎么学习好js,小猿圈web前端讲师总结了JS前端知识点整理,希望对于学习web前端的你有所帮助。

关于offset
多用于检测盒子高度,宽度,位置等
-offsetWidth:盒子的宽度,包括(width,padding,border)
-offsetHeight:盒子的高度,包括(height,padding,border)
-offsetLeft:返回自身距离带有定位的上级盒子左边的位置
-offsetTop:返回自身距离带有定位的上级盒子上边的距离
-offsetParent:返回自身带有定位的父级对象
dom.style.left与dom.offsetLeft的区别
offsetLeft返回的值是数字,style.left返回的带'px'
offsetLeft只读,style.top可读写
offsetLeft本身可以无定位,style.left本身必须有定位属性
关于scroll
scrollTop:盒子或页面滚动距离顶部的距离
scrollLeft:盒子或页面滚动距离左侧的距离
scrollTo:盒子或页面滚动到的位置,参数(x,y)
onscroll:使用onscroll事件检测window或者dom的滚动
页面scrollTop的兼容写法
var scrolltop = window.pageYOffset || document.documentElement.scrollTop || document.body.scrollTop || 0;
关于client
clientWidth:width+padding
clientHeight
scrollWidth:width+padding+(如果有溢出,包括溢出部分)
scrollHeight:height+padding+(如果有溢出,包括溢出部分)
检测屏幕可视区域宽度的兼容写法
function getClientWidth() {
if(!window.innerWidth) {
return {
width: window.innerWidth,
height: window.innerHeight
}
} else if (document.compatMode === "CSS1Compat") {
// 标准模式下
return {
width: document.documentElement.clientWidth,
height: document.documentElement.clientHeight
}
}
// 怪异模式
return {
width:document.body.clientWidth,
height:document.body.clientHeight
}
}
检测电脑屏幕尺寸
window.screen.width
window.screen.height
事件的冒泡
冒泡顺序演示
IE6.0:div>body>html>document
其他浏览器:div>body>html>document>window
不存在冒泡的事件:blur,focus,load,unload
阻止冒泡
借助事件对象evt
标准浏览器:evt.stopPropagation();
IE:evt.cancelBubble=true;
通过事件对象获取事件源对象示例
btn.onclick = function(event) {
var evt = window.event || event;
var target = evt.target ? evt.target : evt.srcElement;
console.log(target);
}
常用的event对象属性
pageX:光标相对于该网页的水平位置(非IE6,7,8属性)
pageY:光标相对于该网页的垂直位置(非IE6,7,8属性)
screenX:光标相对于该屏幕的水平位置
screenY:光标相对于该屏幕的垂直位置
clientX:光标相对于该网页可见区域的水平位置
clientY:光标相对于该网页可见区域的垂直位置
target:该事件被传送到的对象
type:事件的类型
event对象兼容的写法示例
document.onclick = function(event) {
var evt = event || window.event;
}
pageX和pageY的兼容性
pageX = evt.clientX + document.documentElement.scrollLeft;
pageY = evt.clientY + document.documentElement.scrollTop;
以上就是小猿圈web前端老师介绍的JS前端知识点整理总结部分,想要学习web前端的小伙伴可以关注我,每天会分享不同的知识点,相信不会让你失望的web前端自学②群:738735873,学习前端可以到小猿圈网站去看一下最新最全面的前端课程。
网友评论