千锋扣丁学堂HTML5培训之JS前端知识点整理总结(一)
2019-06-27 13:29:06
808浏览
今天千锋扣丁学堂HTML5培训老师给大家分享一篇关于JS前端知识点整理总结(一),介绍了JS前端知识点offset,scroll,client,冒泡,事件对象的应用,结合实例形式总结分析了offset,scroll,client,冒泡,事件对象相关功能、原理及操作注意事项,下面我们一起来一下吧。
关于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;
以上就是关于千锋扣丁学堂HTML5培训之JS前端知识点整理总结(一)的全部内容,
希望对大家的学习有所帮助,想要了解更多关于HTML5开发方面内容的小伙伴,请关注扣丁学堂HTML5培训官网、微信等平台,扣丁学堂IT职业在线学习教育有专业的HTML5讲师为您指导,此外扣丁学堂老师精心推出的HTML5视频教程定能让你快速掌握HTML5从入门到精通开发实战技能。扣丁学堂H5技术交流群:673883249。
【关注微信公众号获取更多学习资料】 【扫码进入HTML5前端开发VIP免费公开课】
查看更多关于“HTML5开发技术资讯”的相关文章>>
标签:
HTML5培训
HTML5视频教程
HTML5学习视频
HTML5在线视频
HTML5培训班
微信小程序